



# A133 User Manual

Revision 1.1

Jul.14, 2020

## DECLARATION

---

THIS DOCUMENTATION IS THE ORIGINAL WORK AND COPYRIGHTED PROPERTY OF ALLWINNER TECHNOLOGY (“ALLWINNER”). REPRODUCTION IN WHOLE OR IN PART MUST OBTAIN THE WRITTEN APPROVAL OF ALLWINNER AND GIVE CLEAR ACKNOWLEDGEMENT TO THE COPYRIGHT OWNER.

THE PURCHASED PRODUCTS, SERVICES AND FEATURES ARE STIPULATED BY THE CONTRACT MADE BETWEEN ALLWINNER AND THE CUSTOMER. PLEASE READ THE TERMS AND CONDITIONS OF THE CONTRACT AND RELEVANT INSTRUCTIONS CAREFULLY BEFORE USING, AND FOLLOW THE INSTRUCTIONS IN THIS DOCUMENTATION STRICTLY. ALLWINNER ASSUMES NO RESPONSIBILITY FOR THE CONSEQUENCES OF IMPROPER USE (INCLUDING BUT NOT LIMITED TO OVERVOLTAGE, OCVERCLOCK, OR EXCESSIVE TEMPERATURE).

THE INFORMATION FURNISHED BY ALLWINNER IS PROVIDED JUST AS A REFERENCE OR TYPICAL APPLICATIONS, ALL STATEMENTS, INFORMATION, AND RECOMMENDATIONS IN THIS DOCUMENT DO NOT CONSTITUTE A WARRANTY OF ANY KIND, EXPRESS OR IMPLIED. ALLWINNER RESERVES THE RIGHT TO MAKE CHANGES IN CIRCUIT DESIGN AND/OR SPECIFICATIONS AT ANY TIME WITHOUT NOTICE.

NOR FOR ANY INFRINGEMENTS OF PATENTS OR OTHER RIGHTS OF THE THIRD PARTIES WHICH MAY RESULT FROM ITS USE. NO LICENSE IS GRANTED BY IMPLICATION OR OTHERWISE UNDER ANY PATENT OR PATENT RIGHTS OF ALLWINNER. THIRD PARTY LICENCES MAY BE REQUIRED TO IMPLEMENT THE SOLUTION/PRODUCT. CUSTOMERS SHALL BE SOLELY RESPONSIBLE TO OBTAIN ALL APPROPRIATELY REQUIRED THIRD PARTY LICENCES. ALLWINNER SHALL NOT BE LIABLE FOR ANY LICENCE FEE OR ROYALTY DUE IN RESPECT OF ANY REQUIRED THIRD PARTY LICENCE. ALLWINNER SHALL HAVE NO WARRANTY, INDEMNITY OR OTHER OBLIGATIONS WITH RESPECT TO MATTERS COVERED UNDER ANY REQUIRED THIRD PARTY LICENCE.

## Revision History

| Revision | Date         | Description                                                                                                                                                                      |
|----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.0      | Jul.07, 2020 | Initial release version                                                                                                                                                          |
| 1.1      | Jul.14, 2020 | <ol style="list-style-type: none"><li>1. Modify the maximum display resolution from 1080p to 1920 x 1200</li><li>2. Delete the limit on the minimum display resolution</li></ol> |
|          |              |                                                                                                                                                                                  |

Confidential

## Contents

---

|                                       |    |
|---------------------------------------|----|
| Chapter 1 About This Document .....   | .5 |
| 1.1. Purpose .....                    | .5 |
| 1.2. Intended Audience.....           | .5 |
| 1.3. Symbol Conventions.....          | .5 |
| 1.4. Notes .....                      | .6 |
| 1.4.1. Register Attributes .....      | .6 |
| 1.4.2. Reset Value Conventions.....   | .6 |
| 1.4.3. Numerical System.....          | .6 |
| 1.5. Acronyms and Abbreviations ..... | .7 |

Confidential

# Chapter 1 About This Document

## 1.1. Purpose

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

## 1.2. Intended Audience

The document is intended for:

- Design and maintenance personnel for electronics
- Sales personnel for electronic parts and components

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

## 1.4. Notes

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

### 1.4.2. Reset Value Conventions

In the register definition tables:

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

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

### 1.4.3. Numerical System

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

| Type                | Symbol | Value         |
|---------------------|--------|---------------|
| Data capacity       | 1K     | 1024          |
|                     | 1M     | 1,048,576     |
|                     | 1G     | 1,073,741,824 |
| Frequency,data rate | 1k     | 1000          |
|                     | 1M     | 1,000,000     |
|                     | 1G     | 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. |
|---|----------|----------------------------------------------------------------------------------------------------------------|

## 1.5. Acronyms and Abbreviations

The following table contains acronyms and abbreviations used in this document.

|       |                                                 |
|-------|-------------------------------------------------|
| ADC   | Analog-to-Digital Converter                     |
| AE    | Automatic Exposure                              |
| AEC   | Audio Echo Cancellation                         |
| AES   | Advanced Encryption Standard                    |
| AF    | Automatic Focus                                 |
| AGC   | Automatic Gain Control                          |
| AHB   | AMBA High-Speed Bus                             |
| ALC   | Automatic Level Control                         |
| ANR   | Active Noise Reduction                          |
| APB   | Advanced Peripheral Bus                         |
| ARM   | Advanced RISC Machine                           |
| AVS   | Audio Video Standard                            |
| AWB   | Automatic White Balance                         |
| BROM  | Boot ROM                                        |
| CIR   | Consumer Infrared                               |
| CMOS  | Complementary Metal-Oxide Semiconductor         |
| CP15  | Coprocessor 15                                  |
| CPU   | Central Processing Unit                         |
| CRC   | Cyclic Redundancy Check                         |
| CSI   | Camera Serial Interface                         |
| CVBS  | Composite Video Broadcast Signal                |
| DDR   | Double Data Rate                                |
| DES   | Data Encryption Standard                        |
| DLL   | Delay-Locked Loop                               |
| DMA   | Direct Memory Access                            |
| DRC   | Dynamic Range Compression                       |
| DVFS  | Dynamic Voltage and Frequency Scaling           |
| ECC   | Error Correction Code                           |
| eFuse | Electrical Fuse, A one-time programmable memory |
| EHCI  | Enhanced Host Controller Interface              |
| eMMC  | Embedded Multi-Media Card                       |
| ESD   | Electrostatic Discharge                         |
| FBGA  | Fine Pitch Ball Grid Array                      |
| FEL   | Fireware Exchange Launch                        |

|       |                                             |
|-------|---------------------------------------------|
| FIFO  | First In First Out                          |
| GIC   | Generic Interrupt Controller                |
| GPIO  | General Purpose Input Output                |
| HD    | High Definition                             |
| HDCP  | High-bandwidth Digital Content Protection   |
| I2C   | Inter Integrated Circuit                    |
| I2S   | Inter IC Sound                              |
| JEDEC | Joint Electron Device Engineering Council   |
| JPEG  | Joint Photographic Experts Group            |
| JTAG  | Joint Test Action Group                     |
| LCD   | Liquid-Crystal Display                      |
| LFBGA | Low Profile Fine Pitch Ball Grid Array      |
| LRADC | Low Rate Analog to Digital Converter        |
| LSB   | Least Significant Bit                       |
| LVDS  | Low Voltage Differential Signaling          |
| MAC   | Media Access Control                        |
| MIC   | Microphone                                  |
| MIPI  | Mobile Industry Processor Interface         |
| MLC   | Multi-Level Cell                            |
| MMC   | Multimedia Card                             |
| MPEG  | Motion Pictures Expert Group                |
| MSB   | Most Significant Bit                        |
| N/A   | Not Application                             |
| NMI   | Non Maskable Interrupt                      |
| NTSC  | National Television Standards Committee     |
| NVM   | Non Volatile Storage Medium                 |
| OHCI  | Open Host Controller Interface              |
| OSD   | On-Screen Display                           |
| OTP   | One Time Programmable                       |
| OWA   | One Wire Audio                              |
| PAL   | Phase Alternating Line                      |
| PCM   | Pulse Code Modulation                       |
| PHY   | Physical Layer Controller                   |
| PID   | Packet Identifier                           |
| PLL   | Phase-Locked Loop                           |
| POR   | Power-On Reset                              |
| PWM   | Pulse Width Modulation                      |
| R     | Read only/non-Write                         |
| RGB   | Read Green Blue                             |
| RGMII | Reduced Gigabit Media Independent Interface |
| RMII  | Reduced Media Independent Interface         |
| ROM   | Read Only Memory                            |
| RSA   | Rivest-Shamir-Adleman                       |
| RTC   | Real Time Clock                             |

|         |                                             |
|---------|---------------------------------------------|
| SAR     | Successive Approximation Register           |
| SD      | Secure Digital                              |
| SDIO    | Secure Digital Input Output                 |
| SDK     | Software Development Kit                    |
| SDRAM   | Synchronous Dynamic Random Access Memory    |
| SDXC    | Secure Digital Extended Capacity            |
| SLC     | Single-Level Cell                           |
| SoC     | System on Chip                              |
| SPI     | Serial Peripheral Interface                 |
| SRAM    | Static Random Access Memory                 |
| TDES    | Triple Data Encryption Standard             |
| TWI     | Two Wire Interface                          |
| UART    | Universal Asynchronous Receiver Transmitter |
| UDF     | Undefined                                   |
| USB OTG | Universal Serial Bus On The Go              |
| UTMI    | USB2.0 Transceiver Macrocell Interface      |

## Contents

|                                     |    |
|-------------------------------------|----|
| Chapter 2 Product Description ..... | 12 |
| 2.1. Overview .....                 | 12 |
| 2.2. Features.....                  | 12 |
| 2.2.1. CPU Architecture .....       | 12 |
| 2.2.2. GPU Architecture.....        | 12 |
| 2.2.3. Memory Subsystem.....        | 13 |
| 2.2.4. Video Engine .....           | 14 |
| 2.2.5. Video and Graphics .....     | 15 |
| 2.2.6. System Peripherals .....     | 15 |
| 2.2.7. Image Input .....            | 18 |
| 2.2.8. Video Output.....            | 18 |
| 2.2.9. Audio Subsystem .....        | 19 |
| 2.2.10. Security Engine.....        | 20 |
| 2.2.11. External Peripherals .....  | 21 |
| 2.2.12. Package .....               | 24 |
| 2.3. Block Diagram .....            | 25 |

## Figures

---

|                                                 |    |
|-------------------------------------------------|----|
| Figure 2- 1. A133 System Block Diagram .....    | 25 |
| Figure 2- 2. A133 Tablet Solution Diagram ..... | 26 |

Confidential

# Chapter 2 Product Description

## 2.1. Overview

A133 is a high-performance quad-core application processor for tablets. The application processor incorporates a high efficient 64-bit quad-core Cortex™-A53 processor, advanced Imagination PowerVR GE8300 GPU, 13M camera ISP, and high-definition 4K@30fps video decoder. Rich memory interfaces (DDR4, DDR3, DDR3L, LPDDR3, LPDDR4, eMMC, Nand) provide high flexibility to support variant memory configurations.

Lots of high-performance interfaces can get very flexible solution, such as MIPI CSI, MIPI DSI, EMAC, USB, UART, SPI, PWM, TWI, LEDC, etc. A133 processor delivers high-performance computing, low-power consumption, and good multimedia experience for tablets. The Allwinner SDK features high stability and ease of use, supports rapid mass production.

## 2.2. Features

### 2.2.1. CPU Architecture

- Quad-core ARM Cortex™-A53 processor@1.6 GHz
- Power-efficient ARM v8 architecture
- 64-bit and 32-bit execution states for scalable high performance
- Trustzone technology supported
- Supports NEON Advanced SIMD (Single Instruction Multiple Data) instruction for acceleration of media and signal processing functions
- VFPv4 Floating Point Unit
- 32 KB L1 Instruction cache and 32 KB L1 Data cache for per CPU
- 512 KB L2 cache shared

### 2.2.2. GPU Architecture

- Imagination GE8300
- Supports OpenGL ES 1.1/2.0/3.2, Vulkan 1.1, OpenCL 1.2

### 2.2.3. Memory Subsystem

#### 2.2.3.1. Boot ROM

- On-chip memory
- Supports system boot from the following devices:
  - SD/eMMC (SMHC0, SMHC2)
  - Nand Flash
  - SPI Nor Flash
  - SPI Nand Flash
- Supports secure boot and normal boot
- Supports mandatory upgrade process through SMHC0 and USB
- Supports GPIO pin to select the kind of boot media to boot
- Supports GPADC to select the kind of boot media to boot
- Supports SID (eFUSE) to select the kind of boot media to boot
- Secure brom supports load only certified firmware
- Secure brom ensures that the secure boot is a trusted environment

#### 2.2.3.2. SDRAM

- 32-bit DDR4/DDR3/DDR3L/LPDDR3/LPDDR4 interface
- DDR4: clock frequency up to 792 MHz
- DDR3/DDR3L: clock frequency up to 792 MHz
- LPDDR3: clock frequency up to 792 MHz
- LRDDR4: clock frequency up to 792 MHz
- Memory capacity up to 4 GB

#### 2.2.3.3. Nand Flash

- Compliant with ONFI 2.0 and Toggle 2.0
- 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 2 chip selects, and 2 ready\_busy signals
- Supports SLC/MLC flash and EF-NAND
- Supports SDR, ONFI DDR1.0, Toggle DDR1.0, ONFI DDR2.0 and Toggle DDR2.0 RAW NAND FLASH

#### 2.2.3.4. SMHC

- Three SD/MMC host controller (SMHC) interfaces
- SMHC0 controls the devices that comply with the Secure Digital (SD3.0)
  - 4-bit bus width

- SDR mode 150MHz@1.8V IO pad
- DDR mode 50MHz@3.3V IO pad
- DDR mode 100MHz@1.8V IO pad
- SMHC1 controls the devices that comply with the Secure Digital Input/Output (SDIO3.0)
  - 4-bit bus width
  - SDR mode 150MHz@1.8V IO pad
  - DDR mode 50MHz@3.3V IO pad
  - DDR mode 100MHz@1.8V IO pad
- SMHC2 controls the devices that comply with the Multimedia Card (eMMC 5.1)
  - 8-bit bus width
  - SDR mode 50MHz@3.3V IO pad
  - SDR mode 150MHz@1.8V IO pad
  - DDR mode 50MHz@3.3V IO pad
  - DDR mode 100MHz@1.8V IO pad
- Supports hardware CRC generation and error detection
- Supports block size of 1 to 65535 bytes

## 2.2.4. Video Engine

### 2.2.4.1. Video Decoding

- Supports multi-formats video decoder, including:
  - H.265 MP@L5.0: 4K@30fps
  - H.264 BP/MP/HP@L5.1: 4K@30fps
  - VP9: 720p@30fps
  - MPEG-4 SP/ASP: 1080p@60fps
  - MPEG-2 MP/HL: 1080p@60fps
  - MPEG-1 MP/HL: 1080p@60fps
  - VP8: 1080p@60fps
  - AVS/AVS+ JiZhun@L6.0: 1080p@60fps
  - H.263 BP: 1080p@60fps
  - MJPEG: 1080p@60fps
  - VC1 SP/MP/AP: 1080p@30fps

### 2.2.4.2. Video Encoding

- H.264 BP/MP/HP
- Maximum 16-megapixel (4096 x 4096) resolution for H.264 encoding
- H.264 encoding performance of 1080p@60fps
- MJPEG encoding performance of 1080p@30fps

## 2.2.5. Video and Graphics

### 2.2.5.1. Display Engine (DE)

- Output size up to 2048 x 2048
- Four alpha blending channels for main display, three channels for aux display
- Four overlay layers in each channel, and has a independent scaler
- Potter-duff compatible blending operation
- Input format: YUV422/YUV420/YUV411/ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555 and RGB565
- Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data
- Supports SmartColor2.0 for excellent display experience
  - Adaptive detail/edge enhancement
  - Adaptive color enhancement
  - Adaptive contrast enhancement and fresh tone rectify
  - Content adaptive backlight control
- Supports write back only for high efficient main display and miracast

### 2.2.5.2. Graphic 2D (G2D)

- Supports layer size up to 2048 x 2048 pixels
- Supports input/output formats: YUV422 (semi-planar and planar format)/YUV420 (semi-planar and planar format)/P010/P210/P410/Y8/ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555/ARGB2101010 and RGB565
- Supports horizontal and vertical flip, clockwise 0/90/180/270 degree rotate

## 2.2.6. System Peripherals

### 2.2.6.1. Timer

- The timer module implements the timing and counting functions, which includes Timer0, Timer1, Watchdog and AVS0, AVS1
  - Timer0 and Timer1 for system scheduler counting
    - Configurable 8 prescale factor
    - Programmable 32-bit down timer
    - Supports two working modes: continue mode and single count mode
    - Generates an interrupt when the count is decreased to 0
  - 1 Watchdog for transmitting a reset signal to reset the entire system after an exception occurs in the system
    - Supports 12 initial values to configure
    - Generation of timeout interrupts
    - Generation of reset signal
    - Watchdog restart the timing
  - 2 AVS counters (AVS0 and AVS1) for synchronizing video and audio in the player
    - Programmable 33-bit up timer
    - Initial value can be updated anytime

- 12-bit frequency divider factor
- Pause/Start function

#### 2.2.6.2. High Speed Timer

- One high speed timer with 56-bit counter
- Configurable 5 prescale factor
- Clock source is synchronized with AHB1 clock, much more accurate than other timers
- Supports 2 working modes: continuous mode and single mode
- Generates an interrupt when the count is decreased to 0

#### 2.2.6.3. 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: 1 kHz
- Configurable initial value by software anytime
- Periodically alarm to wakeup the external devices
- Supports a calibration function of 32.768 kHz obtained by RC16M clock division
- Supports fanout function of internal 32K clock
- 8 general purpose registers for storing power-off information

#### 2.2.6.4. GIC

- Supports 16 Software Generated Interrupts (SGIs), 16 Private Peripheral Interrupts (PPIs) and 160 Shared Peripheral Interrupts (SPIs)
- Enabling, disabling, and generating processor interrupts from hardware interrupt
- Interrupt masking and prioritization

#### 2.2.6.5. DMA

- Up to 8-channel DMA
- Interrupt generated for each DMA channel
- Flexible data width of 8/16/32/64-bit
- Supports linear and IO address modes
- Supports data transfer types with memory-to-memory, memory-to-peripheral, peripheral-to-memory, peripheral-to-peripheral
- Supports transfer with linked list
- DRQ response includes wait mode and handshake mode
- DMA channel supports pause function

#### 2.2.6.6. CCU

- 12 PLLs
- One on-chip RC oscillator
- Supports one external 24 MHz DCXO and one external 32.768 kHz oscillator
- Supports clock configuration and clock generated for corresponding modules
- Supports software-controlled clock gating and software-controlled reset for corresponding modules

#### 2.2.6.7. Thermal Sensor Controller

- Temperature accuracy:  $\pm 3^\circ\text{C}$  from  $0^\circ\text{C}$  to  $+100^\circ\text{C}$ ,  $\pm 5^\circ\text{C}$  from  $-25^\circ\text{C}$  to  $+125^\circ\text{C}$
- Supports over-temperature protection interrupt and over-temperature alarm interrupt
- Averaging filter for thermal sensor reading
- Three thermal sensors: sensor0 located in the CPU, sensor1 located in the GPU, and sensor2 located in the DDR

#### 2.2.6.8. CPU Configuration

- Capable of CPU reset, including core reset, debug circuit reset, etc
- Capable of other CPU-related control, including interface control, CP15 control and power on/off control
- Capable of checking CPU status, including idle status, SMP status, and interrupt status, etc
- Including CPU debug control and status register

#### 2.2.6.9. IOMMU

- Supports virtual address to physical address mapping by hardware implementation
- Supports DE0, VE, CSI, ISP, G2D parallel address mapping
- Supports DE0, VE, CSI, ISP, G2D bypass function independently
- Supports DE0, VE, CSI, ISP, G2D prefetch independently
- Supports DE0, VE, CSI, ISP, G2D 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.2.6.10. Spinlock

- Provides a hardware synchronization mechanism in multi-core system
- Supports 32 lock units to prevent multi processors from handling the shared data at the same time
- Two kinds of lock status: locked and unlocked

- The lock time of the processor is less than 200 cycles

### 2.2.6.11. Message Box

- Provides interrupt communication mechanism for on-chip processor
- The communication parties transmit information by a channel
- Interrupt alarm function

## 2.2.7. Image Input

### 2.2.7.1. CSI

- Supports 2 MIPI CSI interfaces (one for 4-lane, the other for 2-lane)
- Supports image crop function
- Supports MIPI Version 1.0
- Supports up to 1.0 Gbps/lane
- Maximum video capture resolution up to 8M@30fps (for online mode) or 13M@10fps (for offline mode) or 4\*1080p@25fps (for de-interleaver conversion chip)

### 2.2.7.2. ISP

- Supports one sensor in online mode, or two sensors in offline mode
- Maximum frame rate of 8M@30fps (for online mode) or 13M@10fps (for offline mode)
- Adjustable 3A functions, including automatic exposure (AE), automatic white balance (AWB) and automatic focus (AF)
  - Highlight compensation, backlight compensation, gamma correction and color enhancement
  - Defect pixel correction, 2D denoising
  - Global tone mapping
  - Graphics mirror and flip
  - ISP tuning tools for the PC

## 2.2.8. Video Output

### 2.2.8.1. TCON\_LCD

- RGB interface with DE/SYNC mode, up to 1920 x 1200@60fps
- Serial RGB/dummy RGB interface, up to 800 x 480@60fps
- LVDS interface with dual link, up to 1920 x 1200@60fps
- LVDS interface with single link, up to 1366 x 768@60fps
- i8080 interface, up to 800 x 480@60fps
- Supports BT656 interface for NTSC and PAL

- Supports RGB888, RGB666 and RGB565 with dither function
- Supports Gamma correction with R/G/B channel independence

### 2.2.8.2. MIPI DSI

- One 4-lane MIPI DSI
- Compliance with MIPI DSI v1.01
- Compliance with MIPI DCS v1.01, bidirectional communication in LP through data lane 0
- Maximum 1920 x 1200@60fps performance for MIPI DSI
- Supports non-burst mode with sync pulse/sync event, burst mode and command mode
- Supports pixel format: RGB888, RGB666, RGB666 loosely packed and RGB565
- Supports ULPS and escape modes
- Hardware checksum capabilities

### 2.2.9. Audio Subsystem

#### 2.2.9.1. Audio Codec

- Two audio digital-to-analog (DAC) channels
  - Supports 16-bit and 20-bit sample resolution
  - 8 kHz to 192 kHz DAC sample rate
  - $95\pm3$ dB SNR
- Two audio analog-to-digital (ADC) channels
  - Supports 16-bit and 20-bit sample resolution
  - 8 kHz to 48 kHz ADC sample rate
  - $95\pm3$ dB SNR
- Two audio output interfaces:
  - One stereo headphone output (HPOUTL and HPOUTR)
  - One differential line output (LINEOUTLP and LINEOUTLN)
- Two audio input interfaces:
  - Two differential microphone inputs (MICIN1P/N and MICIN2P/N)
  - Two low-noise analog microphone bias output
- Supports Dynamic Range Controller adjusting the DAC playback and ADC capture
- One 128x20-bits FIFO for DAC data transmit, one 128x20-bits FIFO for ADC data receive
- Programmable FIFO thresholds
- DMA and Interrupt support

#### 2.2.9.2. I2S/PCM

- Four I2S/PCM interfaces
- Supports Left-justified, Right-justified, Standard I2S mode, PCM mode, and TDM mode
- I2S mode supports 8 channels, and 32-bit/192 kHz sample rate

- I2S and TDM modes support maximum 16 channels, and 32-bit/96 kHz sample rate

#### 2.2.9.3. DMIC

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

#### 2.2.9.4. OWA

- One OWA TX
- Compliance with S/PDIF interface
- IEC-60958 transmitter functionality
- Supports channel status insertion for the transmitter
- Hardware parity generation on the transmitter
- One 128x24bits TXFIFO for audio data transfer
- Programmable FIFO thresholds
- Interrupt and DMA support
- Supports 16-bit, 20-bit and 24-bit data formats

### 2.2.10. Security Engine

#### 2.2.10.1. Crypto Engine (CE)

- Encryption and decryption algorithms implemented by using hardware, including AES, XTS-AES, DES, TDES, SM4
  - ECB, CBC, CTS, CTR, CFB, OFB, CBC-MAC, GCM mode for AES
  - 128/192/256-bit key for AES
  - 256-bit, 512-bit key for XTS-AES
  - ECB, CBC, CTR, CBC-MAC mode for DES
- Hash tamper proofing algorithms implemented by using hardware, including MD5, SHA, SM3, HMAC
  - SHA1, SHA224, SHA256, SHA384, SHA512 for SHA
  - HMAC-SHA1, HMAC-SHA256 for HMAC
  - Supports hardware padding
  - Supports multi-package mode
- Signature and verification algorithms implemented by using hardware, including RSA, ECC
  - RSA supports 512/1024/2048/3072/4096-bit width
  - ECC supports 160/224/256/384/521-bit width
- Hardware random number generator: PRNG, TRNG, HASH+DRBG
- Security strategy and system feature
  - Symmetric, asymmetric, HASH/RBG ctrl logics are separate, which can handle task simultaneously. Symmetric logic can select instantiate 2 suits at implementation time
  - Supports task chain mode for each request. Task or task chain are executed at request order
  - 8 scatter group (sg) are supported for both input and output data

- Supports secure and non-secure interfaces respectively, each world issues task request through its own interface, they do not know the existence of each other
- Each world has 4 channels for software request, each channel has an interrupt control and status bit, and channels are independent with each other

#### 2.2.10.2. Security ID

- Supports 2 Kbits eFUSE for chip ID and security application
- EFUSE has secure zone and non-secure zone
- Supports a SRAM to backup fuse information

#### 2.2.10.3. Secure Memory Control (SMC)

- The SMC is always secure, only secure CPU can access the SMC
- Set secure area of DRAM
- Set secure property that Master accesses to DRAM
- Set DRM area
- Set whether DRM master can access to DRM area or not

#### 2.2.10.4. Secure Peripherals Control (SPC)

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

### 2.2.11. External Peripherals

#### 2.2.11.1. USB

- One USB 2.0 OTG (USB0), with integrated USB 2.0 analog PHY
  - Compatible with USB2.0 Specification
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) in host mode
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) in device mode
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the Open Host Controller Interface (OHCI) Specification, Version 1.0a for host mode
  - Up to 10 User-Configurable Endpoints (EPs) for Bulk, Isochronous and Interrupt bi-directional transfers
  - Supports (8 KB+64 Bytes) FIFO for all EPs (including EP0)
  - Supports point-to-point and point-to-multipoint transfer in both host and peripheral mode
- One USB 2.0 HOST (USB1), with integrated USB 2.0 analog PHY
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the 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

#### 2.2.11.2. EMAC

- One EMAC interface
- Compliant with IEEE 802.3-2002 standard
- Supports 10/100/1000 Mbit/s data transfer rates
- Supports RMII/RGMII PHY interface
- Supports both full-duplex and half-duplex operation
- Supports MDIO
- 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

#### 2.2.11.3. UART

- Up to 6 UART controllers (UART0, UART1, UART2, UART3, UART4, S\_UART)
- UART0, S\_UART: 2-wire; UART1, UART2, UART3, UART4: 4-wire
- Compatible with industry-standard 16550 UARTs
- Capable of speed up to 4 Mbit/s
- Supports 5 to 8 data bits and 1/1.5/2 stop bits
- Supports even, odd or no parity
- Supports DMA controller interface
- Supports software/hardware flow control
- Supports IrDA 1.0 SIR
- Supports RS-485/9-bit mode

#### 2.2.11.4. SPI

- Up to 3 SPI controllers (SPI0, SPI1, SPI2)
- Full-duplex synchronous serial interface
- Master/slave configurable
- Mode0~3 are supported for both transmit and receive operations
- Two 64 bytes FIFO for both transmit and receive data
- Polarity and phase of the Chip Select (SPI-CS) and SPI Clock (SPI-CLK) are configurable
- Interrupt or DMA support

- Supports 3-wire/4-wire SPI
- Supports programmable serial data frame length: 1-bit to 32-bit
- Supports Standard SPI, Dual-Output/Dual-Input SPI, Dual IO SPI, Quad-Output/Quad-Input SPI

#### 2.2.11.5. Two Wire Interface (TWI)

- Up to 6 TWI controllers (TWI0, TWI1, TWI2, TWI3, S\_TWI0, S\_TWI1)
- Software-programmable for slave or master
- Supports repeated START signal
- Multi-master system supported
- Allows 10-bit addressing transactions
- Performs arbitration and clock synchronization
- Own address and General Call address detection
- Interrupt on address detection
- Supports Standard mode (up to 100 kbit/s) and Fast mode (up to 400 kbit/s)
- Allows operation from a wide range of input clock frequency
- TWI driver supports packet transmission and DMA when TWI works in Master mode

#### 2.2.11.6. PWM

- 5 PWM channels (PWM0~3, S\_PWM)
- PWM0~3 channels divide to 2 PWM pairs: PWM01 pair, PWM23 pair
- S\_PWM channel has the single channel characteristics of PWM module, and has no pair function
- Supports pulse, cycle and complementary pair output
- Supports capture input
- Programming deadzone output
- Build-in the programmable dead-time generator, controllable dead-time
- Three kinds of output waveforms: continuous waveform, pulse waveform and complementary pair
- Output frequency range: 0~24 MHz/100 MHz
- Various duty-cycle: 0%~100%
- Minimum resolution: 1/65536
- Interrupt generation of PWM output and capture input
- Supports PWM group mode(4 groups), the starting phase of each channel in same group is configurable

#### 2.2.11.7. Low Rate ADC (LRADC)

- One LRADC input channel
- 6-bit resolution
- Sample rate up to 2 kHz
- Supports hold Key and general Key
- Supports normal, continue and single work mode
- Power supply voltage: 1.8 V, power reference voltage: 1.35 V, analog input and detected voltage range: 0 to

LEVELB (the maximum value is 1.266 V)

#### 2.2.11.8. General Purpose ADC (GPADC)

- One GPADC input channel
- 12-bit resolution and 8-bit effective SAR type A/D converter
- Power reference voltage: 1.8 V, analog input voltage range: 0 to 1.8 V
- Maximum sampling frequency: 1 MHz
- Supports three operation modes
  - Single conversion mode
  - Continuous conversion mode
  - Outbreak conversion mode

#### 2.2.11.9. LEDC

- LEDC is used to control the external intelligent control LED lamp
- Configurable input high/low level width of LED
- Configurable LED reset time
- LEDC data supports DMA configuration mode and CPU configurable mode
- Maximum 1024 LEDs serial connect

#### 2.2.11.10. CIR Transmitter (CIR\_TX)

- Supports arbitrary wave generator
- Configurable carrier frequency
- Supports DMA shake and wait mode
- 128 bytes FIFO for data buffer

#### 2.2.11.11. CIR Receiver (CIR\_RX)

- Full physical layer implementation
- Supports NEC format infra data
- Supports CIR for remote control or wireless keyboard
- 64x8 bits FIFO for data buffer
- Sample clock up to 1 MHz

#### 2.2.12. Package

- LFBGA346 balls, 0.5 mm ball pitch, 0.3 mm ball size, 12 mm x 12 mm body

## 2.3. Block Diagram

Figure 2-1 shows the system block diagram of the A133.



Figure 2- 1. A133 System Block Diagram

Figure 2-2 shows the tablet solution diagram of the A133.



Figure 2- 2. A133 Tablet Solution Diagram

## Contents

|                                                           |     |
|-----------------------------------------------------------|-----|
| Chapter 3 System .....                                    | 32  |
| 3.1. Memory Mapping .....                                 | 32  |
| 3.2. CPUX Configuration .....                             | 36  |
| 3.2.1. Overview .....                                     | 36  |
| 3.2.2. Operations and Functional Descriptions .....       | 36  |
| 3.2.3. Programming Guidelines .....                       | 38  |
| 3.2.4. Cluster 0 Configuration Register List .....        | 38  |
| 3.2.5. Cluster 0 Configuration Register Description ..... | 38  |
| 3.2.6. CPU Subsystem Control Register List .....          | 43  |
| 3.2.7. CPU Subsystem Control Register Description .....   | 43  |
| 3.3. CCU .....                                            | 48  |
| 3.3.1. Overview .....                                     | 48  |
| 3.3.2. Operations and Functional Descriptions .....       | 48  |
| 3.3.3. Programming Guidelines .....                       | 55  |
| 3.3.4. Register List .....                                | 59  |
| 3.3.5. Register Description .....                         | 62  |
| 3.4. BROM System .....                                    | 133 |
| 3.4.1. Overview .....                                     | 133 |
| 3.4.2. Operations and Functional Descriptions .....       | 133 |
| 3.5. System Configuration .....                           | 139 |
| 3.5.1. Overview .....                                     | 139 |
| 3.5.2. Operations and Functional Descriptions .....       | 139 |
| 3.6. Timer .....                                          | 140 |
| 3.6.1. Overview .....                                     | 140 |
| 3.6.2. Block Diagram .....                                | 141 |
| 3.6.3. Operations and Functional Descriptions .....       | 141 |
| 3.6.4. Programming Guidelines .....                       | 144 |
| 3.6.5. Register List .....                                | 145 |
| 3.6.6. Register Description .....                         | 146 |
| 3.7. High Speed Timer .....                               | 154 |
| 3.7.1. Overview .....                                     | 154 |
| 3.7.2. Block Diagram .....                                | 154 |
| 3.7.3. Operations and Functional Descriptions .....       | 154 |
| 3.7.4. Programming Guidelines .....                       | 156 |
| 3.7.5. Register List .....                                | 157 |
| 3.7.6. Register Description .....                         | 157 |
| 3.8. GIC .....                                            | 163 |
| 3.8.1. Interrupt Source .....                             | 163 |
| 3.9. DMA .....                                            | 168 |

|                                                      |     |
|------------------------------------------------------|-----|
| 3.9.1. Overview .....                                | 168 |
| 3.9.2. Block Diagram .....                           | 168 |
| 3.9.3. Operations and Functional Descriptions .....  | 169 |
| 3.9.4. Programming Guidelines.....                   | 178 |
| 3.9.5. Register List .....                           | 179 |
| 3.9.6. Register Description .....                    | 179 |
| 3.10. Thermal Sensor Controller .....                | 191 |
| 3.10.1. Overview .....                               | 191 |
| 3.10.2. Block Diagram .....                          | 191 |
| 3.10.3. Operations and Functional Descriptions ..... | 191 |
| 3.10.4. Programming Guidelines.....                  | 193 |
| 3.10.5. Register List .....                          | 194 |
| 3.10.6. Register Description .....                   | 195 |
| 3.11. IOMMU .....                                    | 202 |
| 3.11.1. Overview .....                               | 202 |
| 3.11.2. Block Diagram .....                          | 202 |
| 3.11.3. Operations and Functional Descriptions ..... | 203 |
| 3.11.4. Programming Guidelines.....                  | 211 |
| 3.11.5. Register List .....                          | 212 |
| 3.11.6. Register Description .....                   | 215 |
| 3.12. RTC .....                                      | 271 |
| 3.12.1. Overview .....                               | 271 |
| 3.12.2. Clock Tree Diagram.....                      | 271 |
| 3.12.3. Operations and Functional Descriptions ..... | 272 |
| 3.12.4. Programming Guidelines.....                  | 279 |
| 3.12.5. Register List .....                          | 279 |
| 3.12.6. Register Description .....                   | 280 |
| 3.13. Message Box.....                               | 291 |
| 3.13.1. Overview .....                               | 291 |
| 3.13.2. Block Diagram .....                          | 291 |
| 3.13.3. Operations and Functional Descriptions ..... | 292 |
| 3.13.4. Programming Guidelines.....                  | 295 |
| 3.13.5. Register List .....                          | 296 |
| 3.13.6. Register Description .....                   | 296 |
| 3.14. Spinlock .....                                 | 304 |
| 3.14.1. Overview .....                               | 304 |
| 3.14.2. Block Diagram .....                          | 304 |
| 3.14.3. Operations and Functional Descriptions ..... | 304 |
| 3.14.4. Programming Guidelines.....                  | 306 |
| 3.14.5. Register List .....                          | 307 |
| 3.14.6. Register Description .....                   | 308 |

## Figures

|                                                                |     |
|----------------------------------------------------------------|-----|
| Figure 3- 1. CPUX Power Domain Block Diagram.....              | 37  |
| Figure 3- 2. System Bus Tree.....                              | 49  |
| Figure 3- 3. Bus Clock Generation.....                         | 50  |
| Figure 3- 4. Module Clock Generation .....                     | 51  |
| Figure 3- 5. PLL Distribution .....                            | 53  |
| Figure 3- 6. Boot Process Diagram .....                        | 135 |
| Figure 3- 7. Mandatory Upgrade Process .....                   | 136 |
| Figure 3- 8. USB FEL Process .....                             | 137 |
| Figure 3- 9. Timer Block Diagram.....                          | 141 |
| Figure 3- 10. Timer Application Diagram .....                  | 142 |
| Figure 3- 11. HSTimer Block Diagram.....                       | 154 |
| Figure 3- 12. HSTimer Application Diagram .....                | 155 |
| Figure 3- 13. HSTimer Initialization Process.....              | 156 |
| Figure 3- 14. DMA Block Diagram .....                          | 168 |
| Figure 3- 15. DMA Typical Application Diagram .....            | 169 |
| Figure 3- 16. DMA Descriptor .....                             | 171 |
| Figure 3- 17. DMA Chain Transfer .....                         | 173 |
| Figure 3- 18. DMA Transfer Mode .....                          | 175 |
| Figure 3- 19. DMA Transfer Process.....                        | 177 |
| Figure 3- 20. Thermal Sensor Controller Block Diagram.....     | 191 |
| Figure 3- 21. Thermal Sensor Time Requirement .....            | 192 |
| Figure 3- 22. Thermal Sensor Controller Interrupt Source ..... | 192 |
| Figure 3- 23. THS Initial Process .....                        | 193 |
| Figure 3- 24. IOMMU Block Diagram .....                        | 203 |
| Figure 3- 25. Internal Switch Process .....                    | 207 |
| Figure 3- 26. VA-PA Switch Process .....                       | 208 |
| Figure 3- 27. Invalid TLB Address Range .....                  | 209 |
| Figure 3- 28. Level1 Page Table Format.....                    | 210 |
| Figure 3- 29. Level1 Page Table Format.....                    | 210 |
| Figure 3- 30. Read/Write Permission Control .....              | 210 |
| Figure 3- 31. RTC Clock Tree .....                             | 271 |
| Figure 3- 32. RTC Application Diagram .....                    | 273 |
| Figure 3- 33. RTC Counter .....                                | 274 |
| Figure 3- 34. RTC 1KHz Counter Step Structure .....            | 274 |
| Figure 3- 35. Calibration Circuit .....                        | 276 |
| Figure 3- 36. RC Waveform.....                                 | 276 |
| Figure 3- 37. DCXO Timed Wakeup Waveform.....                  | 277 |
| Figure 3- 38. Message Box Block Diagram .....                  | 291 |
| Figure 3- 39. Message Box Typical Application Chart .....      | 293 |
| Figure 3- 40. User1 and User0 Working Process.....             | 295 |

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Figure 3- 41. Spinlock Block Diagram.....                         | 304 |
| Figure 3- 42. Spinlock Typical Application Diagram .....          | 305 |
| Figure 3- 43. Spinlock State Machine.....                         | 305 |
| Figure 3- 44. CPU0 and CPUS Taking/Freeing Spinlock0 Process..... | 306 |

Confidential

## Tables

|                                                                     |     |
|---------------------------------------------------------------------|-----|
| Table 3- 1. Reset Signal Description.....                           | 36  |
| Table 3- 2. BOOT_MODE Setting.....                                  | 133 |
| Table 3- 3. GPADC Boot Select Setting.....                          | 134 |
| Table 3- 4. GPIO Pin Boot Select Configuration .....                | 134 |
| Table 3- 5. eFuse Boot Select Configuration .....                   | 134 |
| Table 3- 6. eFuse Boot Select Setting.....                          | 135 |
| Table 3- 7. Fast Boot Select Setting.....                           | 138 |
| Table 3- 8. DMA DRQ Table.....                                      | 170 |
| Table 3- 9. Source/Destination Address Distribution .....           | 172 |
| Table 3- 10. Correspondence Relation between Master and Module..... | 203 |
| Table 3- 11. Relation between ACI and Domain .....                  | 211 |
| Table 3- 12. RTC External Signals .....                             | 272 |
| Table 3- 13. RTC Counter Changing Range.....                        | 274 |

# Chapter 3 System

## 3.1. Memory Mapping

| Module             | Address(It is for Cluster CPU) | Size(Bytes)                                                                                                                                                                                                                      |
|--------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N_BROM             | 0x0000 0000---0x0000 FFFF      | 64K                                                                                                                                                                                                                              |
| S_BROM             | 0x0000 0000—0x0000 BFFF        | 48K                                                                                                                                                                                                                              |
| SRAM A1            | 0x0002 0000---0x0002 3FFF      | 16K(support Byte operation, clock source is AHB1)                                                                                                                                                                                |
| SRAM C             | 0x0002 4000---0x0004 4FFF      | Borrow VE 112K, DE 20K, supports Byte operation, clock source is AHB1                                                                                                                                                            |
| SRAM A2            | 0x0010 0000---0x0011 3FFF      | 16K + 64K<br>0x0010 0000---0x00103FFF:<br>only store CPUS Vector Table, and<br>only 16 addresses are valid,<br>0x00100100,<br>0x00100200...0x00100F00.<br>See Openrisc, the real space of SRAM<br>A2 is 0x00104000---0x0011 3FFF |
| <b>Accelerator</b> |                                |                                                                                                                                                                                                                                  |
| GPU                | 0x0180 0000---0x0187 FFFF      | 512K                                                                                                                                                                                                                             |
| GPU_SYS            | 0x0188 0000---0x0188 03FF      | 1K                                                                                                                                                                                                                               |
| CE_NS              | 0x0190 4000---0x0190 47FF      | 2K                                                                                                                                                                                                                               |
| CE_S               | 0x0190 4800---0x0190 4FFF      | 2K                                                                                                                                                                                                                               |
| CE_KEY_SRAM        | 0x0190 8000---0x0190 8FFF      | 4K                                                                                                                                                                                                                               |
| VE SRAM            | 0x01A0 0000---0x01BF FFFF      | 2M                                                                                                                                                                                                                               |
| VE                 | 0x01C0 E000---0x01C0 FFFF      | 8K                                                                                                                                                                                                                               |
| <b>Video Input</b> |                                |                                                                                                                                                                                                                                  |
| CSIC               | 0x0200 0000---0x021F FFFF      | 2M                                                                                                                                                                                                                               |
| CSIC_CCU           | 0x0200 0000---0x0200 07FF      | 2K                                                                                                                                                                                                                               |
| CSIC_TOP           | 0x0200 0800---0x0200 0FFF      | 2K                                                                                                                                                                                                                               |
| CSIC_PARSER0       | 0x0200 1000---0x0200 1FFF      | 4K                                                                                                                                                                                                                               |
| CSIC_PARSER1       | 0x0200 2000---0x0200 2FFF      | 4K                                                                                                                                                                                                                               |
| CSIC_DMA0          | 0x0200 9000---0x0200 91FF      | 0.5K                                                                                                                                                                                                                             |
| CSIC_DMA1          | 0x0200 9200---0x0200 93FF      | 0.5K                                                                                                                                                                                                                             |
| CSIC_DMA2          | 0x0200 9400---0x0200 95FF      | 0.5K                                                                                                                                                                                                                             |

|                         |                           |      |
|-------------------------|---------------------------|------|
| CSIC_DMA3               | 0x0200 9600---0x0200 97FF | 0.5K |
| CSIC_COMBO              | 0x0200 A000---0x0200 BFFF | 8K   |
| CSIC_ISP0               | 0x0210 0000---0x0210 1FFF | 8K   |
| CSIC_ISP1               | 0x0210 2000---0x0210 3FFF | 8K   |
| CSIC_TDM                | 0x0210 8000---0x0210 83FF | 1K   |
| CSIC_VIPPO              | 0x0211 0000---0x0211 03FF | 1K   |
| CSIC_VIPP1              | 0x0211 0400---0x0211 07FF | 1K   |
| CSIC_VIPP2              | 0x0211 0800---0x0211 0BFF | 1K   |
| CSIC_VIPP3              | 0x0211 0C00---0x0211 0FFF | 1K   |
| CSIC_SRAM               | 0x0220 0000---0x028F FFFF | 7M   |
| TOP_PKT_SRAM            | 0x0220 0000---0x0220 01FF | 0.5K |
| BRIDGE_SRAM             | 0x0221 0000---0x0221 3FFF | 16K  |
| DMA_SRAM                | 0x0222 0000---0x0223 FFFF | 128K |
| MBUS_SRAM               | 0x0224 0000---0x0224 1FFF | 8K   |
| VIPPO_SRAM              | 0x0230 0000---0x0231 FFFF | 128K |
| VIPP1_SRAM              | 0x0232 0000---0x0233 FFFF | 128K |
| VIPP2_SRAM              | 0x0234 0000---0x0235 FFFF | 128K |
| VIPP3_SRAM              | 0x0236 0000---0x0237 FFFF | 128K |
| ISP_SRAM                | 0x0240 0000---0x027F FFFF | 4M   |
| TDM_SRAM                | 0x0280 0000---0x0281 FFFF | 128K |
| <b>System Resources</b> |                           |      |
| SYS_CFG                 | 0x0300 0000---0x0300 0FFF | 4K   |
| CCU                     | 0x0300 1000---0x0300 1FFF | 4K   |
| DMA                     | 0x0300 2000---0x0300 2FFF | 4K   |
| MSGBOX                  | 0x0300 3000---0x0300 3FFF | 4K   |
| SPINLOCK                | 0x0300 4000---0x0300 4FFF | 4K   |
| HSTIMER                 | 0x0300 5000---0x0300 5FFF | 4K   |
| SID                     | 0x0300 6000---0x0300 6FFF | 4K   |
| SPC                     | 0x0300 8000---0x0300 83FF | 1K   |
| TIMER                   | 0x0300 9000---0x0300 93FF | 1K   |
| PWM                     | 0x0300 A000---0x0300 A3FF | 1K   |
| GPIO                    | 0x0300 B000---0x0300 B3FF | 1K   |
| PSI                     | 0x0300 C000---0x0300 C3FF | 1K   |
| GIC                     | 0x0302 0000---0x0302 FFFF | 64K  |
| IOMMU                   | 0x030F 0000---0x030F FFFF | 64K  |
| NSI                     | 0x0310 0000---0x0310 FFFF | 64K  |
| <b>Memory</b>           |                           |      |
| NAND0                   | 0x0401 1000---0x0401 1FFF | 4K   |
| SMHC0                   | 0x0402 0000---0x0402 0FFF | 4K   |
| SMHC1                   | 0x0402 1000---0x0402 1FFF | 4K   |
| SMHC2                   | 0x0402 2000---0x0402 2FFF | 4K   |
| DRAM                    | 0x0480 0000---0x048F FFFF | 1M   |
| SMC                     | 0x0480 0000---0x0480 FFFF | 64K  |
| DRAM_TOP                | 0x0481 0000---0x0481 FFFF | 64K  |

|                     |                           |      |
|---------------------|---------------------------|------|
| DDRCTL              | 0x0482 0000---0x0482 FFFF | 64K  |
| DDRPHY              | 0x0483 0000---0x0483 FFFF | 64K  |
| <b>Interfaces</b>   |                           |      |
| UART0               | 0x0500 0000---0x0500 03FF | 1K   |
| UART1               | 0x0500 0400---0x0500 07FF | 1K   |
| UART2               | 0x0500 0800---0x0500 0BFF | 1K   |
| UART3               | 0x0500 0C00---0x0500 0FFF | 1K   |
| UART4               | 0x0500 1000---0x0500 13FF | 1K   |
| TWI0                | 0x0500 2000---0x0500 23FF | 1K   |
| TWI1                | 0x0500 2400---0x0500 27FF | 1K   |
| TWI2                | 0x0500 2800---0x0500 2BFF | 1K   |
| TWI3                | 0x0500 2C00---0x0500 2FFF | 1K   |
| SPI0                | 0x0501 0000---0x0501 0FFF | 4K   |
| SPI1                | 0x0501 1000---0x0501 1FFF | 4K   |
| SPI2                | 0x0501 2000---0x0501 2FFF | 4K   |
| LEDC                | 0x0501 8000---0x0501 83FF | 1K   |
| EMAC0               | 0x0502 0000---0x0502 FFFF | 64K  |
| GPADC               | 0x0507 0000---0x0507 03FF | 1K   |
| THS                 | 0x0507 0400---0x0507 07FF | 1K   |
| LRADC               | 0x0507 0800---0x0507 0BFF | 1K   |
| CIR_TX              | 0x0507 1000---0x0507 13FF | 1K   |
| CIR_RX              | 0x0507 1800---0x0507 1BFF | 1K   |
| I2S0                | 0x0509 0000---0x0509 0FFF | 4K   |
| I2S1                | 0x0509 1000---0x0509 1FFF | 4K   |
| I2S2                | 0x0509 2000---0x0509 2FFF | 4K   |
| I2S3                | 0x0509 3000---0x0509 3FFF | 4K   |
| OWA                 | 0x0509 4000---0x0509 43FF | 1K   |
| DMIC                | 0x0509 5000---0x0509 53FF | 1K   |
| Audio Codec         | 0x0509 6000---0x0509 6FFF | 4K   |
| USB0(USB2.0_OTG)    | 0x0510 0000---0x051F FFFF | 1M   |
| USB1(USB2.0_HOST)   | 0x0520 0000---0x052F FFFF | 1M   |
| <b>Display</b>      |                           |      |
| DE0                 | 0x0600 0000---0x063F FFFF | 4M   |
| G2D                 | 0x0648 0000---0x064B FFFF | 256K |
| DSI0                | 0x0650 4000---0x0650 5FFF | 8K   |
| DSI_CORE            | 0x0650 4000---0x0650 43FF | 1K   |
| DSI_CONFIG_REG      | 0x0650 4400---0x0650 4FFF | 3K   |
| DPSS_TOPO           | 0x0651 0000---0x0651 0FFF | 4K   |
| TCON_LCD0           | 0x0651 1000---0x0651 1FFF | 4K   |
| <b>CPUS Related</b> |                           |      |
| RTC                 | 0x0700 0000---0x0700 03FF | 1K   |
| R_CPUS_CFG          | 0x0700 0400---0x0700 0BFF | 2K   |
| R_PPU               | 0x0700 1000---0x0700 13FF | 1K   |
| R_PRCM              | 0x0701 0000---0x0701 03FF | 1K   |

|                     |                            |    |
|---------------------|----------------------------|----|
| R_TIMER             | 0x0702 0000---0x0702 03FF  | 1K |
| R_WDG               | 0x0702 0400---0x0702 07FF  | 1K |
| R_TWDG              | 0x0702 0800---0x0702 0BFF  | 1K |
| R_PWM               | 0x0702 0C00---0x0702 0FFF  | 1K |
| R_INTC              | 0x0702 1000---0x0702 13FF  | 1K |
| R_GPIO              | 0x0702 2000---0x0702 23FF  | 1K |
| R_CPUUS_MBIST       | 0x0703 1000---0x0703 1FFF  | 4K |
| R_CIR_RX            | 0x0704 0000---0x0704 03FF  | 1K |
| R_UART              | 0x0708 0000---0x0708 03FF  | 1K |
| R_TWI0              | 0x0708 1400---0x0708 17FF  | 1K |
| R_TWI1              | 0x0708 1800---0x0708 1BFF  | 1K |
| <b>CPUX Related</b> |                            |    |
| CPU_SUBSYS_CFG      | 0x0810 0000---0x0810 03FF  | 1K |
| TIMESTAMP_STU       | 0x0811 0000---0x0811 0FFF  | 4K |
| TIMESTAMP_CTRL      | 0x0812 0000---0x0812 0FFF  | 4K |
| IDC                 | 0x0813 0000---0x0813 0FFF  | 3K |
| PLL_CPU_CFG         | 0x0814 0000---0x0814 03FF  | 1K |
| C0_CPUX_CFG         | 0x0901 0000---0x0901 03FF  | 1K |
| C0_CPUX_MBIST       | 0x0902 0000---0x0902 0FFF  | 4K |
| <b>DRAM</b>         |                            |    |
| DRAM                | 0x4000 0000---0x13FFF FFFF | 4G |

## 3.2. CPUX Configuration

### 3.2.1. Overview

The C0\_CPUX\_CFG module is used for configuring cluster0 (quad-core Cortex-A53, 32 KB I-cache and 32 KB D-cache, 512 KB L2 cache), such as reset, control, cache, debug, CPU status.

The CPU\_SUBSYS\_CTRL module is used for the system resource control of CPU sub-system, such as GIC-400, JTAG, etc.

The CPUX\_CFG includes the following features:

- CPU reset system: core reset, debug circuit reset and other reset function
- CPU related control: interface control, CP15 control, power-on/off control
- CPU status check: idle status, SMP status, interrupt status
- CPU control and status register about debug related

### 3.2.2. Operations and Functional Descriptions

#### 3.2.2.1. Signal Description

For the detail of CPUX signal, please refer to **ARM Cortex-A53 TRM**, such as [DDI0464F\\_cortex\\_A53\\_mpcore\\_r0p5\\_trm.pdf](#).

#### 3.2.2.2. L2 Idle Mode

When the L2 cache of cluster needs to enter WFI mode, firstly make sure that the CPU[3:0] of cluster enters WFI mode, which can be checked through the bit[19:16] of **Cluster CPU Status Register**, and then pull high the **ACINACTM** of cluster by writing 1 to the bit0 of **Cluster Control Register1**, and then check whether L2 enters idle status by checking whether the **STANDBYWFL2** is high. Note that set the **ACINACTM** to low when exiting the L2 idle mode.

#### 3.2.2.3. CPUX Reset System

The CPUX reset includes **core reset**, **power-on reset** and **H\_Reset**. And their scopes rank: **core reset < power-on Reset < H\_Reset**. The description of all reset signal in CPUX reset system is as follows.

**Table 3- 1. Reset Signal Description**

| Reset Signal | Description                                                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_RST     | This is the primary reset signal which can reset the corresponding core logic including NEON, VFP, Debug, ETM, breakpoint and watchpoint logic.<br>It maps to a warm reset that covers reset of the processor logic. |

|                |                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PWRON_RST      | This power-on reset signal resets all the processor logic, including the Debug, ETM trace unit, breakpoint, watchpoint logic, and performance monitors logic.<br>It maps to a cold reset that covers reset of the processor logic and the integrated debug functionality. This does not reset debug logic in the debug power domain.<br>Including CORE_RST/ETM_RST/DBG_RST. |
| AXI2MBUS_RST   | Reset the AXI2MBUS interface logic circuit.                                                                                                                                                                                                                                                                                                                                 |
| L2_RST         | This single, cluster-wide signal resets the L2 memory system and the logic in the SCU.                                                                                                                                                                                                                                                                                      |
| ETM_RST        | Reset ETM debug logic circuit.                                                                                                                                                                                                                                                                                                                                              |
| DBG_RST        | Reset only the debug, and breakpoint and watchpoint logic in the processor power domain. It also resets the debug logic for each processor in the debug power domain.                                                                                                                                                                                                       |
| SOC_DBG_RST    | Reset all the debug logic including DBG_RST.                                                                                                                                                                                                                                                                                                                                |
| MBIST_RST      | Reset all resettable registers in the cluster, for entry into, and exit from, MBIST mode.                                                                                                                                                                                                                                                                                   |
| H_RST          | Including PWRON_RST/L2_RST/MBIST_RST/SOC_DBG_RST/C0_CPUX_CFG.                                                                                                                                                                                                                                                                                                               |
| CPU_SUBSYS_RST | Including C0_H_RST/GIC-400/CPU_SUBSYS_CTRL.                                                                                                                                                                                                                                                                                                                                 |

### 3.2.2.4. CPUX Power Block Diagram



Figure 3-1. CPUX Power Domain Block Diagram

Figure 3-1 lists the power domain of cluster in default. The power switch of all CPU core are power-on, the pwrone\_rst of all CPU core are de-asserted, the core reset of CPU0 is de-asserted, the core reset of CPU [3:1] is asserted.

Since each CPU core and its appended circuits have the same power domain, the processor and related L1 cache, neon and vfp should be taken as a whole core.

C0\_CPUX\_CFG and cluster0 belong to the same power domain, within opening and closing cluster0 process, when cluster0 starts to power on again from power-off state, C0\_CPUX\_CFG holds in default state, at this time software need initial C0\_CPUX\_CFG after C0\_H\_RST is de-asserted.

CPU\_SUBSYS\_CTRL belongs to system power domain. The power domains of CPU related module are as follows.

| Power Domain | Modules                       | Description                                  |
|--------------|-------------------------------|----------------------------------------------|
| Cluster0     | Cluster0/C0_CPUX_CFG/C0_MBIST | Cluster0 circuit, C0_CPUX_CFG module and CPU |

|        |                                     |                                                                                                                                   |
|--------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
|        |                                     | reset/power/mbist                                                                                                                 |
| System | Timestamp/GIC/CPU_SUBSYS_CTRL/Clock | Provide system source of CPU sub-system                                                                                           |
| CPUS   | CPUS_CFG                            | It is used for power on/off control of CORE or Cluster.<br>Note that CPUS_CFG belongs to system power domain in SoC without CPUS. |

### 3.2.2.5. Operation Principle

The CPU-related operations (such as open/close core, cluster switch, status query) need proper configuration of C0\_CPUX\_CFG module, as well as the combination of related system control resources including BUS, clock.

### 3.2.3. Programming Guidelines

For CPU core and cluster operation, please see the [A133\\_CPU\\_AP\\_Note](#).

### 3.2.4. Cluster 0 Configuration Register List

| Module Name | Base Address |
|-------------|--------------|
| C0_CPUX_CFG | 0x09010000   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| C0_RST_CTRL   | 0x0000 | Cluster 0 Reset Control Register  |
| C0_CTRL_REG0  | 0x0010 | Cluster 0 Control Register0       |
| C0_CTRL_REG1  | 0x0014 | Cluster 0 Control Register1       |
| C0_CTRL_REG2  | 0x0018 | Cluster 0 Control Register2       |
| CACHE_CFG_REG | 0x0024 | Cache Configuration Register      |
| C0_CPU_STATUS | 0x0080 | Cluster 0 CPU Status Register     |
| L2_STATUS_REG | 0x0084 | Cluster 0 L2 Status Register      |
| DBG_REG0      | 0x00C0 | Cluster 0 Debug Control Register0 |
| DBG_REG1      | 0x00C4 | Cluster 0 Debug Control Register1 |

### 3.2.5. Cluster 0 Configuration Register Description

#### 3.2.5.1. 0x0000 Cluster 0 Reset Control Register(Default Value: 0x13FF\_0101)

| Offset: 0x0000 |            |             | Register Name: C0_RST_CTRL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:29          | /          | /           | /                          |
| 28             | R/W        | 0x1         | DDR_RST                    |

|       |     |     |                                                                                         |
|-------|-----|-----|-----------------------------------------------------------------------------------------|
|       |     |     | AXI2MBUS Logic Circuit Reset<br>0: assert<br>1: de-assert                               |
| 27:26 | /   | /   | /                                                                                       |
| 25    | R/W | 0x1 | MBIST_RST<br>CPUBIST Reset<br>The reset signal is for test<br>0: assert<br>1: de-assert |
| 24    | R/W | 0x1 | SOC_DBG_RST<br>Cluster SOC Debug Reset<br>0: assert<br>1: de-assert                     |
| 23:20 | R/W | 0xF | ETM_RST<br>Cluster ETM Reset Assert<br>0: assert<br>1: de-assert                        |
| 19:16 | R/W | 0xF | DBG_RST<br>Cluster Debug Reset Assert<br>0: assert<br>1: de-assert                      |
| 15:9  | /   | /   | /                                                                                       |
| 8     | R/W | 0x1 | L2_RST<br>Cluster L2 Cache Reset<br>0: assert<br>1: de-assert                           |
| 7:4   | /   | /   | /                                                                                       |
| 3:0   | R/W | 0x1 | CORE_RESET<br>Cluster CPU[3:0] Reset Assert.<br>0: assert<br>1: de-assert               |

### 3.2.5.2. 0x0010 Cluster 0 Control Register0(Default Value: 0x8000\_0000)

| Offset: 0x0010 |            |             | Register Name: C0_CTRL_REG0                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x1         | SYSBAR_DISABLE<br>Disable broadcasting of barriers onto system bus<br>0: Barriers are broadcasted onto system bus, this requires an AMBA4 interconnect<br>1: Barriers are not broadcasted onto the system bus. This is compatible with an AXI3 interconnect |
| 30             | R/W        | 0x0         | BROADCAST_INNER<br>Enable broadcasting of inner shareable transactions                                                                                                                                                                                      |

|       |     |     |                                                                                                                                                                                                                                                       |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: Inner shareable transactions are not broadcasted externally<br>1: Inner shareable transactions are broadcasted externally                                                                                                                          |
| 29    | R/W | 0x0 | BROADCAST_OUTER<br>Enable broadcasting of outer shareable transactions<br>0: Outer shareable transactions are not broadcasted externally<br>0: Outer shareable transactions are broadcasted externally                                                |
| 28    | R/W | 0x0 | BROADCAST_CACHE_MAINT<br>Enable broadcasting of cache maintenance operations to downstream caches<br>0: Cache maintenance operations are not broadcasted to downstream caches<br>1: Cache maintenance operations are broadcasted to downstream caches |
| 27:12 | /   | /   | /                                                                                                                                                                                                                                                     |
| 11:8  | R/W | 0x0 | CP15S_DISABLE<br>Disable write access to some secure CP15 register.                                                                                                                                                                                   |
| 7:5   | /   | /   | /                                                                                                                                                                                                                                                     |
| 4     | R/W | 0x0 | L2_RST_DISABLE<br>Disable automatic L2 cache invalidate at reset<br>0: L2 cache is reset by hardware<br>1: L2 cache is not reset by hardware                                                                                                          |
| 3:0   | R/W | 0x0 | L1_RST_DISABLE.<br>Disable automatic Cluster CPU[3:0] L1 cache invalidate at reset:<br>0: L1 cache is reset by hardware.<br>1: L1 cache is not reset by hardware.                                                                                     |

### 3.2.5.3. 0x0014 Cluster 0 Control Register1(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            | Register Name: C0_CTRL_REG1 |                                                                                                                                         |
|----------------|------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex                 | Description                                                                                                                             |
| 31:2           | /          | /                           | /                                                                                                                                       |
| 1              | R/W        | 0x0                         | CRM auto select slow frequency enable<br>0: disable auto select<br>1: enable auto select                                                |
| 0              | R/W        | 0x0                         | ACINACTM<br>Snoop interface is inactive and no longer accepts request<br>0: Snoop interface is active<br>1: Snoop interface is inactive |

### 3.2.5.4. 0x0018 Cluster 0 Control Register2(Default Value: 0x0000\_0010)

| Offset: 0x0018 |            | Register Name: C0_CTRL_REG2 |             |
|----------------|------------|-----------------------------|-------------|
| Bit            | Read/Write | Default/Hex                 | Description |

|       |     |     |                                                                                                                                                |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:25 | /   | /   | /                                                                                                                                              |
| 24    | R/W | 0x0 | EVENTI<br>Event input for processor wake-up from WFE state. This bit must remain high for at least one clock cycle to be visible by the cores. |
| 23:20 | R/W | 0x0 | EXM_CLR[3:0]<br>Clear the status of interface.                                                                                                 |
| 19:0  | /   | /   | /                                                                                                                                              |

### 3.2.5.5. 0x0024 Cache Configuration Register(Default Value: 0x0018\_001A)

| Offset: 0x0024 |            |             | Register Name: CACHE_CFG_REG                |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:22          | /          | /           | /                                           |
| 21:19          | R/W        | 0x3         | EMA_L2D<br>L2 Cache SRAM EMA control port   |
| 18:17          | R/W        | 0x0         | EMAW_L2D<br>L2 Cache SRAM EMAW control port |
| 16             | R/W        | 0x0         | EMAS_L2D<br>L2 Cache SRAM EMAS control port |
| 15:6           | /          | /           | /                                           |
| 5:3            | R/W        | 0x3         | EMA<br>Cache SRAM EMA control port          |
| 2:1            | R/W        | 0x1         | EMAW<br>Cache SRAM EMAW control port        |
| 0              | R/W        | 0x0         | EMAS<br>Cache SRAM EMAS control port        |

### 3.2.5.6. 0x0080 Cluster0 CPU Status Register(Default Value: 0x000E\_0000)

| Offset: 0x0080 |            |             | Register Name: C0_CPU_STATUS                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31:28          | /          | /           | /                                                                                                                                               |
| 27:24          | R          | 0x0         | SMP_AMP<br>CPU[3:0] is in Symmetric Multiprocessing mode or Asymmetric Multiprocessing mode.<br>0: AMP mode<br>1: SMP mode                      |
| 23:20          | /          | /           | /                                                                                                                                               |
| 19:16          | R          | 0x1         | STANDBYWFI<br>Indicates if Cluster CPU[3:0] is in WFI standby mode<br>0: Processor not in WFI standby mode.<br>1: Processor in WFI standby mode |

|       |   |     |                                                                                                                                                               |
|-------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:12 | / | /   | /                                                                                                                                                             |
| 11:8  | R | 0x0 | STANDBYWFE<br>Indicates if Cluster CPU[3:0] is in the WFE standby mode<br>0: Processor not in WFE standby mode<br>1: Processor in WFE standby mode            |
| 7:1   | / | /   | /                                                                                                                                                             |
| 0     | R | 0x0 | STANDBYWFL2<br>Indicates if the Cluster L2 memory system is in WFI standby mode<br>0: Cluster L2 not in WFI standby mode<br>1: Cluster L2 in WFI standby mode |

### 3.2.5.7. 0x0084 L2 Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: L2_STATUS_REG                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:10          | /          | /           | /                                                                                                                              |
| 9              | R          | 0x0         | EVENTO<br>Event output. This bit is asserted HIGH for 3 clock cycles when any core in the cluster executes an SEV instruction. |
| 8:0            | /          | /           | /                                                                                                                              |

### 3.2.5.8. 0x00C0 Cluster 0 Debug Control Register0(Default Value:0x0000\_000F)

| Offset: 0x00C0 |            |             | Register Name: DBG_REG0                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:12          | /          | /           | /                                                                                          |
| 11:8           | R/W        | 0x0         | DBGRESTART[3:0]<br>External restart requests.                                              |
| 7:4            | /          | /           | /                                                                                          |
| 3:0            | R/W        | 0x1         | C_DBGPWRDUP[3:0]<br>Cluster Powered-up<br>0: Core is powered down<br>1: Core is powered up |

### 3.2.5.9. 0x00C4 Cluster 0 Debug Control Register1(Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: DBG_REG1                        |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31:16          | /          | /           | /                                              |
| 15:12          | R/W        | 0x0         | DBGRESTARTED[3:0]<br>Handshake for DBGRESTART. |

|      |   |     |                                                                                                                                                             |
|------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8 | / | /   | /                                                                                                                                                           |
| 7:4  | R | 0x0 | C_DBGNOPWRDWN<br>No power-down request. Debugger has requested that processor is not powered down.<br>Debug no power down[3:0].                             |
| 3:0  | R | 0x0 | C_DBGPWRUPREQ<br>Power up request<br>Debug power up request[3:0]<br>0: Do not request that the core is powered up<br>1: Request that the core is powered up |

### 3.2.6. CPU Subsystem Control Register List

| Module Name     | Base Address |
|-----------------|--------------|
| CPU_SUBSYS_CTRL | 0x08100000   |

| Register Name     | Offset | Description                                |
|-------------------|--------|--------------------------------------------|
| GENER_CTRL_REG0   | 0x0000 | General Control Register0                  |
| GIC_JTAG_RST_CTRL | 0x000C | GIC and JTAG Reset Control Register        |
| C0_INT_EN         | 0x0010 | Cluster0 Interrupt Enable Control Register |
| IRQ_FIQ_STATUS    | 0x0014 | IRQ/FIQ Status Register                    |
| GENER_CTRL_REG2   | 0x0018 | General Control Register2                  |
| DBG_STATE         | 0x001C | Debug State 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      |

### 3.2.7. CPU Subsystem Control Register Description

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

| Offset: 0x0000 |            | Register Name: GENER_CTRL_REG0 |                                       |
|----------------|------------|--------------------------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex                    | Description                           |
| 31:8           | /          | /                              | /                                     |
| 7:4            | R/W        | 0x0                            | Cluster 0 AA64NAA32<br>Register width |

|   |     |     |                                                                                    |
|---|-----|-----|------------------------------------------------------------------------------------|
|   |     |     | 0: AArch32<br>1: AArch64<br>This pin is sampled only during reset of the processor |
| 3 | /   | /   | /                                                                                  |
| 2 | R/W | 0x0 | Cluster 0 corepll select<br>0: CCU clock<br>1: disp pll clock                      |
| 1 | R/W | 0x0 | IDC clock enable<br>0: Disable IDC clock<br>1: Enable IDC clock                    |
| 0 | R/W | 0x0 | GIC_CFGSDISABLE<br>Disable write access to some secure GIC registers.              |

### 3.2.7.2. 0x000C GIC and Jtag Reset Control Register(Default Value: 0x0000\_0F07)

| 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:12          | /          | /           | /                                                                        |
| 11             | R/W        | 0x1         | CS_RST<br>CoreSight Reset.<br>0: assert<br>1: de-assert                  |
| 10             | R/W        | 0x1         | DAP_RST<br>DAP Reset<br>0: assert<br>1: de-assert                        |
| 9              | R/W        | 0x1         | PORTRST<br>Jtag portrst<br>0: assert<br>1: de-assert                     |
| 8              | R/W        | 0x1         | TRST<br>Jtag trst<br>0: assert<br>1: de-assert                           |
| 7:2            | /          | /           | /                                                                        |
| 1              | R/W        | 0x1         | IDC_RST<br>Interrupt delay controller reset<br>0: assert<br>1: de-assert |
| 0              | R/W        | 0x1         | GIC_RST                                                                  |

|  |  |  |                                                |
|--|--|--|------------------------------------------------|
|  |  |  | GIC_reset_cpu_reg<br>0: assert<br>1: de-assert |
|--|--|--|------------------------------------------------|

### 3.2.7.3. 0x0010 Cluster 0 Interrupt Enable Register(Default Value: 0x0000\_FFFF)

| Offset: 0x0010 |            |             | Register Name: C0_INT_EN                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:16          | /          | /           | /                                                                                          |
| 15:0           | R/W        | 0xFFFF      | C0_GIC_EN<br>Interrupt enable control register.<br>Mask irq_out/firq_out to system domain. |

### 3.2.7.4. 0x0014 GIC IRQ/FIQ Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: IRQ_FIQ_STATUS |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | R/W        | 0x0000      | FIQ_OUT[15:0]                 |
| 15:0           | R/W        | 0x0000      | IRQ_OUT[15:0]                 |

### 3.2.7.5. 0x0018 General Control Register2(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: GENER_CTRL_REG2                    |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:17          | /          | /           | /                                                 |
| 16             | R/W        | 0x0         | CDBGRSTACK<br>Debug Reset ACK                     |
| 15:1           | /          | /           | /                                                 |
| 0              | R/W        | 0x0         | C0_TSCLKCHANGE<br>Cluster 0 Time Stamp change bit |

### 3.2.7.6. 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_PWRSW_STA                                             |
| 23:1           | /          | /           | /                                                         |
| 0              | R          | 0x0         | C0_DBG_STATE<br>Cluster 0 is in debug mode or normal mode |

### 3.2.7.7. 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[31:2] for executing in 64-bit state (AArch64) of CPU0. |
| 1:0            | /          | /           | /                                                                                                   |

### 3.2.7.8. 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:32] for executing in 64-bit state (AArch64) of CPU0. |

### 3.2.7.9. 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[31:2] for executing in 64-bit state (AArch64) of CPU1. |
| 1:0            | /          | /           | /                                                                                                   |

### 3.2.7.10. 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:32] for executing in 64-bit state (AArch64) of CPU1. |

### 3.2.7.11. 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[31:2] for executing in 64-bit state (AArch64) of CPU2. |
| 1:0  | /   | /   | /                                                                                                   |

### 3.2.7.12. 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:32] for executing in 64-bit state (AArch64) of CPU2. |

### 3.2.7.13. 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[31:2] for executing in 64-bit state (AArch64) of CPU3. |
| 1:0            | /          | /           | /                                                                                                   |

### 3.2.7.14. 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:32] for executing in 64-bit state (AArch64) of CPU3. |

## 3.3. CCU

### 3.3.1. Overview

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

The CCU includes the following features:

- 12 PLLs
- Bus source and divisions
- Clock output control
- PLL bias control
- PLL tuning control
- PLL pattern control
- Configuring modules clock
- Bus clock gating
- Bus software reset
- PLL lock control

### 3.3.2. Operations and Functional Descriptions

#### 3.3.2.1. System Bus Tree

Figure 3-2 shows a block diagram of the system bus tree.

The system bus tree is used to introduce bus interface of every module. These modules can divide into two types: the master and slave of bus. For example, DMA, BIST\_MST(Built-in Self Test Master), CE, SMHC0/1/2, CPUS, CPUX and DS(Debug System) are as bus master that can access corresponding register of every slave through bus. Every slave hangs in corresponding bus.

For example, CPU accesses to RTC module, the process is as follows: CPU instruction firstly passes AXI bus, then goes to PSI bus through AXI2PSI bridge, then goes to AHBS bus through PSI2AHB bridge, and goes to APBS2 through AHB2APB, finally RTC is operated based on relevant bus protocol. The access time from CPU to RTC, is relevant with the CPU clock, AXI bus clock, PSI bus clock, AHBS bus clock and APBS2 bus clock. Any lower bus clock will lead to access time very long.

In above module, the clocks of these modules(such as TWI and UART) to be hung on APB2/APBS2 are from their respective bus clock, however the clocks of most other modules are from related CLK register, such as DE\_CLK\_REG. Each module clock requirement can refer to their module.



Figure 3-2. System Bus Tree

### 3.3.2.2. Bus Clock Generation

Figure 3-3 describes bus clock generation.



Figure 3-3. Bus Clock Generation

### 3.3.2.3. Module Clock Generation

Figure 3-4 describes module clock generation.



Figure 3-4. Module Clock Generation

| Module           | Clock Name                | DIV1 | DIV2    | Source0        | Source1        | Source2        | Source3        | Source4        |
|------------------|---------------------------|------|---------|----------------|----------------|----------------|----------------|----------------|
| CPU              | CPU_CLK                   | 1~4  | 1~4     | OSC24M         | CLK32K         | CLK16M_RC      | CPU_PLL        | PLL_PERIO(1X)  |
| PSI/AHB1/AHB2    | PSI_CLK,AHB1_CLK,AHB2_CLK | 1~4  | 1/2/4/8 | OSC24M         | CLK32K         | CLK16M_RC      | PLL_PERIO(1X)  | PLL_PERIO(2X)  |
| AHB3/AHB_MSTG    | AHB3_CLK                  | 1~4  | 1/2/4/8 | OSC24M         | CLK32K         | PSI_CLK        | PLL_PERIO(1X)  | PLL_PERIO(2X)  |
| APB1             | APB1_CLK                  | 1~4  | 1/2/4/8 | OSC24M         | CLK32K         | PSI_CLK        | PLL_PERIO(1X)  | PLL_PERIO(2X)  |
| APB2             | APB2_CLK                  | 1~4  | 1/2/4/8 | OSC24M         | CLK32K         | PSI_CLK        | PLL_PERIO(1X)  | PLL_PERIO(2X)  |
| MBUS/NSI         | MBUS_CLK                  | 1~8  | /       | OSC24M         | PLL_DDR        | PLL_PERIO(1X)  | PLL_PERIO(2X)  | /              |
| DE0              | DE0_CLK                   | 1~16 | /       | PLL_COM        | PLL_PERIO(2X)  | /              | /              | /              |
| G2D              | G2D_CLK                   | 1~16 | /       | PLL_COM        | PLL_PERIO(2X)  | PLL_VIDEO0(2X) | PLL_VIDEO1(2X) | PLL_VIDEO2(2X) |
| GPU              | GPUCORE_CLK               | 1~8  | /       | PLL_GPU        | /              | /              | /              | /              |
| CE               | CE_CLK                    | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(2X)  | /              | /              | /              |
| VE               | VE_CLK                    | 1~8  | /       | PLL_VE         | PLL_PERIO(2X)  | /              | /              | /              |
| AVS              | AVS_CLK                   | /    | /       | OSC24M         | /              | /              | /              | /              |
| DRAM             | DRAM_CLK                  | 1~32 | /       | PLL_DDR        | PLL_PERI1(2X)  | /              | /              | /              |
| NAND0_0          | NAND0_CLK0                | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | PLL_PERIO(2X)  | PLL_PERI1(2X)  |
| NAND0_1          | NAND0_CLK1                | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | PLL_PERIO(2X)  | PLL_PERI1(2X)  |
| SMHC0            | SMHC0_CLK                 | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(2X)  | PLL_PERI1(2X)  | /              | /              |
| SMHC1            | SMHC1_CLK                 | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(2X)  | PLL_PERI1(2X)  | /              | /              |
| SMHC2            | SMHC2_CLK                 | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(2X)  | PLL_PERI1(2X)  | /              | /              |
| SPI0             | SPI0_CLK                  | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | PLL_PERIO(2X)  | PLL_PERI1(2X)  |
| SPI1             | SPI1_CLK                  | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | PLL_PERIO(2X)  | PLL_PERI1(2X)  |
| SPI2             | SPI2_CLK                  | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | PLL_PERIO(2X)  | PLL_PERI1(2X)  |
| EMAC0_25M        | EMAC0_CLK25M_FANOUT       | /    | /       | EMAC_25M_CLK   | /              | /              | /              | /              |
| CIR_RX           | IRRX_CLK                  | 1~16 | 1/2/4/8 | CLK32K         | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | /              |
| CIR_TX           | IRTX_CLK                  | 1~16 | 1/2/4/8 | CLK32K         | OSC24M         | PLL_PERIO(1X)  | PLL_PERI1(1X)  | /              |
| I2S/PCM0         | I2SPCM0_CLK               | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| I2S/PCM1         | I2SPCM1_CLK               | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| I2S/PCM2         | I2SPCM2_CLK               | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| I2S/PCM3         | I2SPCM3_CLK               | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| OWA              | OWA_CLK                   | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| DMIC             | DMIC_CLK                  | /    | 1/2/4/8 | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| AUDIOCODEC1X_DAC | AUDIOCODEC1X_DAC_CLK      | 1~16 | /       | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| AUDIOCODEC1X_ADC | AUDIOCODEC1X_ADC_CLK      | 1~16 | /       | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| AUDIOCODEC4X     | AUDIOCODEC4X_CLK          | 1~16 | /       | PLL_AUDIO(4X)  | PLL_COM_AUDIO  | /              | /              | /              |
| MIPIHOST0        | MIPIHOST0_CLK             | 1~16 | /       | OSC24M         | PLL_PERIO(2X)  | PLL_PERIO(1X)  | /              | /              |
| TCONLCD0         | TCONLCD0_CLK              | 1~16 | 1/2/4/8 | PLL_VIDEO0(4X) | PLL_VIDEO1(4X) | PLL_VIDEO2(4X) | PLL_VIDEO3(4X) | PLL_PERIO(2X)  |
| LEDC             | LEDC_CLK                  | 1~16 | 1/2/4/8 | OSC24M         | PLL_PERIO(1X)  | /              | /              | /              |
| CSITOP           | CSITOP_CLK                | 1~16 | /       | PLL_PERIO(2X)  | PLL_VIDEO0(2X) | PLL_VIDEO1(2X) | PLL_VIDEO2(2X) | PLL_VIDEO3(2X) |
| CSIMASTER        | CSIMASTER_CLK             | 1~32 | /       | OSC24M         | PLL_VIDEO2(1X) | PLL_VIDEO3(1X) | PLL_VIDEO0(1X) | PLL_VIDEO1(1X) |
| CSIMASTER1       | CSIMASTER1_CLK            | 1~32 | /       | OSC24M         | PLL_VIDEO3(1X) | PLL_VIDEO0(1X) | PLL_VIDEO1(1X) | PLL_VIDEO2(1X) |
| ISP              | ISP_CLK                   | 1~16 | /       | PLL_PERIO(2X)  | PLL_VIDEO0(2X) | PLL_VIDEO1(2X) | PLL_VIDEO2(2X) | PLL_VIDEO3(2X) |

### 3.3.2.4. PLL Distribution

Figure 3-5 shows the block diagram of the PLL distribution.



Figure 3-5. PLL Distribution

| PLL Type                                             | Application Module                                                                                                             | Note                                                                                                           |
|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| PLL_CPUX                                             | CPUX, CPUX_AXI                                                                                                                 | The PLL_CPUX supports dynamic modification of frequency factors to achieve DVFS.                               |
| PLL_DDR                                              | MBUS, DRAM                                                                                                                     | The PLL_DDR supports spread spectrum, and does not support linear frequency modulation.                        |
| PLL_PERIO(2X)                                        | MBUS, PSI, AHB1, AHB2, AHB3, APB1, APB2, DE0, G2D, CE, VE, NAND, SMHC0/1/2, SPI0/1/2, ISP, CSIO_TOP, MIPI_DSI_HOST0, TCON_LCD0 | The PLL_PERIO(2X) does not support dynamic frequency modulation.                                               |
| PLL_PERIO(1X)                                        | MBUS, PSI, AHB1, AHB2, AHB3, APB1, APB2, NAND, SPI0/1/2, LEDC, CIR_RX, CIR_TX, MIPI_DSI_HOST0, CPUX, CPUX_AXI                  | The PLL_PERIO(1X) does not support dynamic frequency modulation.                                               |
| PLL_PERI1(2X)                                        | DRAM, NAND, SMHC0/1/2, SPI0/1/2                                                                                                | The output clock of PLL_PERI1(2X) is 1.2 GHz. The PLL_PERI1(2X) does not support dynamic frequency modulation. |
| PLL_PERI1(1X)                                        | NAND, SPI0/1/2, CIR_RX, CIR_TX                                                                                                 | The output clock of PLL_PERI1(1X) is 600 MHz. The PLL_PERI1(1X) does not support dynamic frequency modulation. |
| PLL_VE                                               | VE                                                                                                                             | The PLL_VE does not support dynamic frequency modulation.                                                      |
| PLL_COM                                              | DE0/1, G2D                                                                                                                     | The PLL_COM does not support dynamic frequency modulation.                                                     |
| PLL_COM_AUDIO                                        | I2S/PCM0/1/2/3, DMIC, OWA, AUDIO_CODEC_ADC/DAC_1X, AUDIO_CODEC_4X                                                              |                                                                                                                |
| PLL_AUDIO(4X)                                        | I2S/PCM0/1/2/3, DMIC, OWA, AUDIO_CODEC_ADC/DAC_1X, AUDIO_CODEC_4X                                                              | The PLL_AUDIO(4X) does not support DVFS.                                                                       |
| PLL_VIDEO0(1X)/<br>PLL_VIDEO1(1X)/<br>PLL_VIDEO2(1X) | CSI_MASTER0/1                                                                                                                  | The PLL_VIDEO0(1X)/PLL_VIDEO1(1X)/PLL_VIDEO2(1X) does not support dynamic frequency modulation.                |
| PLL_VIDEO0(2X)/<br>PLL_VIDEO1(2X)/<br>PLL_VIDEO2(2X) | G2D, CSI_TOP, ISP                                                                                                              | The PLL_VIDEO0(2X)/PLL_VIDEO1(2X)/PLL_VIDEO2(2X) does not support dynamic frequency modulation.                |
| PLL_VIDEO0(4X)/<br>PLL_VIDEO1(4X)/<br>PLL_VIDEO2(4X) | TCON_LCD0                                                                                                                      | The PLL_VIDEO0(4X)/PLL_VIDEO1(4X)/PLL_VIDEO2(4X) does not support dynamic frequency modulation.                |
| PLL_VIDEO3(1X)                                       | CSI_MASTER0/1                                                                                                                  | The PLL_VIDEO3(1X) does not support dynamic frequency modulation.                                              |
| PLL_VIDEO3(2X)                                       | CSI_TOP, ISP                                                                                                                   | The PLL_VIDEO3(2X) does not support dynamic frequency modulation.                                              |
| PLL_VIDEO3(4X)                                       | TCON_LCD0                                                                                                                      | The PLL_VIDEO3(4X) does not support dynamic frequency                                                          |

|  |  |             |
|--|--|-------------|
|  |  | modulation. |
|--|--|-------------|

### 3.3.3. Programming Guidelines

#### 3.3.3.1. Frequency Adjustment of PLL\_CPUX

The frequency configuration formula of PLL\_CPUX:  $\text{PLL\_CPUX} = 24\text{MHz} * \text{N}/\text{P}$ , where, the N parameter is frequency-doubling factor of PLL, the next parameter configuration can proceed after PLL relock; the P parameter is digital post-frequency division, which can be dynamically switched in real time, and it does not affect the normal work of PLL.

The CPU PLL supports dynamic frequency configuration (modify the value of N). The CPU should first switch to a lower intermediate frequency and then adjust to the target frequency when switching the frequency. The process is as follows.

- (1) Before you configure PLL\_CPU, switch the clock source of CPU to PLL\_PERIO(1X).
- (2) Modify the N, P parameter of PLL\_CPU.
- (3) Write the PLL Lock Enable bit to 0 and then write it to 1.
- (4) Wait the Lock bit (bit28) of PLL\_CPUX\_CTRL to 1.
- (5) Switch the clock source of CPU to PLL\_CPU.

#### 3.3.3.2. Frequency Adjustment of PLL\_AUDIO

The frequency configuration formula of PLL\_AUDIO:  $\text{PLL\_AUDIO} = 24\text{MHz} * \text{N}/\text{M0}/\text{M1}/\text{P}$ . Changing any parameter of N, M0, M1 and P will affect the normal work of PLL, which needs to be relocked. Therefore, dynamic adjustment is not supported.

For PLL\_AUDIO, two frequency points usually are needed:  $24.576 * 4\text{MHz}$  and  $22.5792 * 4\text{MHz}$ . There are generally specific recommended configuration factors for the two frequencies. To implement the desired frequency point of PLL\_AUDIO, you need to use the decimal frequency division function. The process is as follows.

- (1) Configure the N, M1, M0, P factor.
- (2) Configure the PLL\_SDM\_ENABLE bit of PLL\_AUDIO\_CTRL to 1.
- (3) Configure PLL\_AUDIO\_PATO\_CTRL to enable digital spread spectrum.
- (4) Write the PLL Lock Enable bit of PLL\_AUDIO\_CTRL to 0 and then write it to 1.
- (5) Wait the Lock bit (bit28) of PLL\_AUDIO\_CTRL to 1.



#### NOTE

The P factor of PLL\_AUDIO is odd number, the clock output is non-equal duty.

#### 3.3.3.3. Frequency Adjustment of PLL\_DDR

For the clock of DDR, the switch of the clock source and the frequency division coefficient is burless, but the

frequency adjustment of the module should follow the following rules.

- From high frequency to low frequency: switch the clock source first, and then set the frequency division coefficient;
- From low frequency to high frequency: switch the frequency division coefficient first, and then modify clock source.

#### 3.3.3.4. Frequency Adjustment of General PLL

- (1) At present, the PLL should be enabled. If the PLL is not enabled, refer to the PLL process from disable to enable in section 3.3.3.5. For PLL, it is not suggested to switch during PLL using. When clock is not needed, it is suggested to configure the PLL\_OUTPUT\_EN bit of PLL\_CTRL to 0 to disable the output gate of PLL.
- (2) General PLL cannot be used in the process of frequency modulation. It is suggested to configure the PLL\_OUTPUT\_EN bit of PLL\_CTRL to 0 in the process of PLL adjustment.
- (3) Configure the N, M1, M0 factor. (It is not suggested to configure M1 factor, configure according to <>PLL recommended configuration table>>)
- (4) Write the PLL Lock Enable bit (bit29) of PLL\_CTRL to 0 and then write it to 1.
- (5) Wait the Lock bit (bit28) of PLL\_CTRL to 1.
- (6) Configure PLL\_OUTPUT\_EN to 1.

#### 3.3.3.5. PLL Disable to PLL Enable

- (1) Configure the N, M1, M0 factor of PLL\_CTRL\_REG.
- (2) Write the Enable bit of PLL\_CTRL\_REG to 1.
- (3) Write the Lock Enable bit of PLL\_CTRL\_REG to 1.
- (4) Wait the status of Lock to 1.
- (5) Delay 20us, the PLL can be used.

#### 3.3.3.6. PLL Enable to PLL Disable

- (1) Write the Enable bit of PLL to 0.
- (2) Write the Lock Enable bit (bit29) of PLL\_CTRL\_REG to 0.



#### CAUTION

In the normal using of PLL, it is not recommended to switch PLL frequently, because the switch of PLL will cause mutual interference between PLL, which will affect the stability of the system. Therefore, it is recommended to turn off PLL by configuring the PLL\_OUTPUT\_EN bit of PLL\_CTRL to 0, instead of writing 0 to the enable bit.

### 3.3.3.7. Bus Configuration

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

- From high frequency to low frequency: switch the clock source first, and then set the frequency division factor;
- From low frequency to high frequency: switch the frequency division factor first, and then switch clock source.

### 3.3.3.8. Module Clock Configuration

For the bus gating and reset register of modules, the reset is de-asserted first, and then the CLK gating is enabled, to ensure that no problem will occur due to the module not being reset synchronously released.

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

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

### 3.3.3.9. Spread Spectrum Function

#### 3.3.3.9.1. Configuration Process

The configuration of spread spectrum follows the following steps.

##### Step1: Configure PLL\_CTRL Register

- According to PLL frequency and PLL frequency formula, calculate factor N and decimal value X, and write M0、M1、N and PLL frequency to the PLL\_CTRL register.
- Configure the SDM\_Enable bit(bit24) of the PLL\_CTRL register to 1 to enable spread spectrum function.

##### Step 2: Configure PLL\_PAT Register

- According to decimal value X and spread spectrum frequency(the bit[18:17] of the PLL\_PAT register), calculate SDM\_BOT and WAVE\_STEP of PLL\_PAT register.
- Configure spread spectrum mode(SPR\_FREQ\_MODE) to 2 or 3.
- Configure the spread spectrum clock source select bit(SDM\_CLK\_SEL) to 0 by default. But if the PLL\_INPUT\_DIV\_M1 bit of the PLL\_CTRL register is 1, the bit should set to 1.
- Write SDM\_BOT、WAVE\_STEP、PREQ、SPR\_FREQ\_MODE and SDM\_CLK\_SEL to the PLL\_PAT register, and configure the SIG\_DELT\_PAT\_EN bit(bit31) of this register to 1.

##### Step 3: Delay 20us

### 3.3.3.9.2. Configuration Instruction

(1).The spread spectrum is an additional low frequency periodic frequency at the desired frequency point, which is not related with the configuration parameters(N, P, M1, M0) of the frequency point.

(2).The parameter M0, P is not related with the configuration of spread spectrum, only used for frequency division configuration.

### 3.3.3.9.3. Frequency Calculation Formula

$$f = \frac{N+1+X}{P \cdot (M0+1) \cdot (M1+1)} \cdot 24\text{MHz}, 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 spread spectrum.



#### NOTE

Having different PLL calculate formula for different PLL, please refer to each PLL\_CTRL register.

If selecting M1 = 0, M0 = 0, P = 1(no frequency division)

Then the above formula can be simplified:

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

$$\triangleright f_1 \sim f_2 = [N+1+(X_1 \sim X_2)] \cdot 24\text{MHz}$$

$$\triangleright \text{SDM\_BOT} = 2^{17} \cdot X1$$

$$\triangleright \text{WAVE\_STEP} = 2^{17} \cdot (X2 - X1) / (24\text{MHz}/\text{PREQ}) * 2, 0 < X < 1$$

PREQ is the frequency of spread spectrum.



#### NOTE

For decimal frequency division, the formula can be referenced by it, at this time X1 is equal to X2.

### 3.3.3.9.4. Configuration Example

Configure 605.3 MHz ~ 609.7 MHz

M0 = 1,

$$N + 1 + (X_1 \sim X_2) = (605.3 \sim 609.7) / 24 = [600 + (5.3 \sim 9.7)] / 24 = 24 + 1 + (5.3/24 \sim 9.7/24)$$

Calculate to get the following values:

$$N = 24, X1 = 5.3/24, X2 = 9.7/24$$

$$SDM\_BOT = 2^{17} * X1 = 0x7111$$

$$WAVE\_STEP = 2^{17} * (X2 - X1) / (24M/PREQ)*2 = 0x3f; PREQ = 31.5 \text{ kHz}$$

If M0 = 1, P = 1, then total frequency division factor is  $(M0 + 1) * 1 = 2$ ,

So the actual output frequency of PLL is 1212.1 MHz ~ 1219.4 MHz.

Calculate to get the following values:

$$N = 49, X1 = 12.1/24, X2 = 19.4/24$$

Then calculate based on SDM\_BOT and WAVE\_STEP formula.

### 3.3.4. Register List

| Module Name | Base Address |
|-------------|--------------|
| CCU         | 0x03001000   |

| Register Name            | Offset | Description                          |
|--------------------------|--------|--------------------------------------|
| PLL_CPUX_CTRL_REG        | 0x0000 | PLL_CPUX Control Register            |
| PLL_DDR_CTRL_REG         | 0x0010 | PLL_DDR Control Register             |
| PLL_PERIO_CTRL_REG       | 0x0020 | PLL_PERIO 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_COM_CTRL_REG         | 0x0060 | PLL_COM Control Register             |
| PLL_VIDEO3_CTRL_REG      | 0x0068 | PLL_VIDEO3 Control Register          |
| PLL_AUDIO_CTRL_REG       | 0x0078 | PLL_AUDIO Control Register           |
| PLL_DDR_PATO_CTRL_REG    | 0x0110 | PLL_DDR Pattern0 Control Register    |
| PLL_DDR_PAT1_CTRL_REG    | 0x0114 | PLL_DDR Pattern1 Control Register    |
| PLL_PERIO_PATO_CTRL_REG  | 0x0120 | PLL_PERIO Pattern0 Control Register  |
| PLL_PERIO_PAT1_CTRL_REG  | 0x0124 | PLL_PERIO Pattern1 Control Register  |
| PLL_PERI1_PATO_CTRL_REG  | 0x0128 | PLL_PERI1 Pattern0 Control Register  |
| PLL_PERI1_PAT1_CTRL_REG  | 0x012C | PLL_PERI1 Pattern1 Control Register  |
| PLL_GPU0_PATO_CTRL_REG   | 0x0130 | PLL_GPU0 Pattern0 Control Register   |
| PLL_GPU0_PAT1_CTRL_REG   | 0x0134 | PLL_GPU0 Pattern1 Control Register   |
| PLL_VIDEO0_PATO_CTRL_REG | 0x0140 | PLL_VIDEO0 Pattern0 Control Register |
| PLL_VIDEO0_PAT1_CTRL_REG | 0x0144 | PLL_VIDEO0 Pattern1 Control Register |
| PLL_VIDEO1_PATO_CTRL_REG | 0x0148 | PLL_VIDEO1 Pattern0 Control Register |
| PLL_VIDEO1_PAT1_CTRL_REG | 0x014C | PLL_VIDEO1 Pattern1 Control Register |
| PLL_VIDEO2_PATO_CTRL_REG | 0x0150 | PLL_VIDEO2 Pattern0 Control Register |

|                          |        |                                      |
|--------------------------|--------|--------------------------------------|
| PLL_VIDEO2_PAT1_CTRL_REG | 0x0154 | PLL_VIDEO2 Pattern1 Control Register |
| PLL_VE_PATO_CTRL_REG     | 0x0158 | PLL_VE Pattern0 Control Register     |
| PLL_VE_PAT1_CTRL_REG     | 0x015C | PLL_VE Pattern1 Control Register     |
| PLL_COM_PATO_CTRL_REG    | 0x0160 | PLL_COM Pattern0 Control Register    |
| PLL_COM_PAT1_CTRL_REG    | 0x0164 | PLL_COM Pattern1 Control Register    |
| PLL_VIDEO3_PATO_CTRL_REG | 0x0168 | PLL_VIDEO3 Pattern0 Control Register |
| PLL_VIDEO3_PAT1_CTRL_REG | 0x016C | PLL_VIDEO3 Pattern1 Control Register |
| PLL_AUDIO_PATO_CTRL_REG  | 0x0178 | PLL_AUDIO Pattern0 Control Register  |
| PLL_AUDIO_PAT1_CTRL_REG  | 0x017C | PLL_AUDIO Pattern1 Control Register  |
| PLL_CPUX_BIAS_REG        | 0x0300 | PLL_CPUX Bias Register               |
| PLL_DDR_BIAS_REG         | 0x0310 | PLL_DDR Bias Register                |
| PLL_PERIO_BIAS_REG       | 0x0320 | PLL_PERIO Bias Register              |
| PLL_PERI1_BIAS_REG       | 0x0328 | PLL_PERI1 Bias Register              |
| PLL_GPU0_BIAS_REG        | 0x0330 | PLL_GPU0 Bias Register               |
| PLL_VIDEO0_BIAS_REG      | 0x0340 | PLL_VIDEO0 Bias Register             |
| PLL_VIDEO1_BIAS_REG      | 0x0348 | PLL_VIDEO1 Bias Register             |
| PLL_VIDEO2_BIAS_REG      | 0x0348 | PLL_VIDEO2 Bias Register             |
| PLL_VE_BIAS_REG          | 0x0358 | PLL_VE Bias Register                 |
| PLL_COM_BIAS_REG         | 0x0360 | PLL_COM Bias Register                |
| PLL_VIDEO3_BIAS_REG      | 0x0368 | PLL_VIDEO3 Bias Register             |
| PLL_AUDIO_BIAS_REG       | 0x0378 | PLL_AUDIO Bias Register              |
| PLL_CPUX_TUN_REG         | 0x0400 | PLL_CPUX Tuning Register             |
| C0_CPUX_AXI_CFG_REG      | 0x0500 | CPUX_AXI Configuration Register      |
| PSI_AHB1_AHB2_CFG_REG    | 0x0510 | PSI_AHB1_AHB2 Configuration Register |
| AHB3_CFG_REG             | 0x051C | AHB3 Configuration Register          |
| APB1_CFG_REG             | 0x0520 | APB1 Configuration Register          |
| APB2_CFG_REG             | 0x0524 | APB2 Configuration Register          |
| MBUS_CFG_REG             | 0x0540 | MBUS Configuration Register          |
| DE0_CLK_REG              | 0x0600 | DE0 Clock Register                   |
| DE_BGR_REG               | 0x060C | DE Bus Gating Reset Register         |
| G2D_CLK_REG              | 0x0630 | G2D Clock Register                   |
| G2D_BGR_REG              | 0x063C | G2D Bus Gating Reset Register        |
| GPU_CORE_CLK_REG         | 0x0670 | GPU Clock Register                   |
| GPU_BGR_REG              | 0x067C | GPU Bus Gating Reset 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         |
| DMA_BGR_REG              | 0x070C | DMA Bus Gating Reset Register        |
| MSGBOX_BGR_REG           | 0x071C | MSGBOX Bus Gating Reset Register     |
| SPINLOCK_BGR_REG         | 0x072C | SPINLOCK Bus Gating Reset Register   |
| HSTIMER_BGR_REG          | 0x073C | HSTIMER Bus Gating Reset Register    |
| AVS_CLK_REG              | 0x0740 | AVS Clock Register                   |

|                            |        |                                       |
|----------------------------|--------|---------------------------------------|
| DBGSYS_BGR_REG             | 0x078C | DBGSYS Bus Gating Reset Register      |
| PSI_BGR_REG                | 0x079C | PSI Bus Gating Reset Register         |
| PWM_BGR_REG                | 0x07AC | PWM Bus Gating Reset 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        |
| NAND0_0_CLK_REG            | 0x0810 | NAND0_0 Clock Register                |
| NAND0_1_CLK_REG            | 0x0814 | NAND0_1 Clock Register                |
| NAND_BGR_REG               | 0x082C | NAND Bus Gating Reset Register        |
| SMHCO_CLK_REG              | 0x0830 | SMHCO 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        |
| 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                   |
| SPI_BGR_REG                | 0x096C | SPI Bus Gating Reset Register         |
| EMAC0_25M_CLK_REG          | 0x0970 | EMAC0_25M Clock Register              |
| EMAC_BGR_REG               | 0x097C | EMAC Bus Gating Reset Register        |
| IRRX_CLK_REG               | 0x0990 | IRRX Clock Register                   |
| 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_BGR_REG              | 0x09EC | GPADC Bus Gating Reset Register       |
| THS_BGR_REG                | 0x09FC | THS Bus Gating Reset Register         |
| I2SPCM0_CLK_REG            | 0x0A10 | I2S/PCM0 Clock Register               |
| I2SPCM1_CLK_REG            | 0x0A14 | I2S/PCM1 Clock Register               |
| I2SPCM2_CLK_REG            | 0x0A18 | I2S/PCM2 Clock Register               |
| I2SPCM3_CLK_REG            | 0x0A1C | I2S/PCM3 Clock Register               |
| I2SPCM_BGR_REG             | 0x0A20 | I2S/PCM Bus Gating Reset Register     |
| OWA_CLK_REG                | 0x0A24 | OWA Clock Register                    |
| OWA_BGR_REG                | 0x0A2C | OWA Bus Gating Reset Register         |
| DMIC_CLK_REG               | 0x0A40 | DMIC Clock Register                   |
| DMIC_BGR_REG               | 0x0A4C | DMIC Bus Gating Reset Register        |
| AUDIO_CODEC_DAC_1X_CLK_REG | 0x0A50 | AUDIO CODEC DAC 1X Clock Register     |
| AUDIO_CODEC_ADC_1X_CLK_REG | 0x0A54 | AUDIO CODEC ADC 1X Clock Register     |
| AUDIO_CODEC_4X_CLK_REG     | 0x0A58 | AUDIO CODEC 4X Clock Register         |
| AUDIO_CODEC_BGR_REG        | 0x0A5C | AUDIO CODEC Bus Gating Reset Register |
| USB0_CLK_REG               | 0x0A70 | USB0 Clock Register                   |
| USB1_CLK_REG               | 0x0A74 | USB1 Clock Register                   |

|                        |        |                                          |
|------------------------|--------|------------------------------------------|
| USB_BGR_REG            | 0x0A8C | USB Bus Gating Reset Register            |
| LRADC_BGR_REG          | 0x0A9C | LRADC Bus Gating Reset Register          |
| DPSS_TOP0_BGR_REG      | 0x0ABC | DPSS_TOP0 Bus Gating Reset Register      |
| DPSS_TOP1_BGR_REG      | 0x0ACC | DPSS_TOP1 Bus Gating Reset Register      |
| MIPI_DSI_HOST0_CLK_REG | 0x0B24 | MIPI DSI Host0 Clock Register            |
| MIPI_BGR_REG           | 0x0B4C | MIPI DSI Bus Gating Reset Register       |
| DISPLAY_IF_TOP_BGR_REG | 0x0B5C | DISPLAY_IF_TOP Bus Gating Reset Register |
| TCON_LCD0_CLK_REG      | 0x0B60 | TCON LCD0 Clock Register                 |
| TCON_LCD_BGR_REG       | 0x0B7C | TCON LCD Bus Gating Reset Register       |
| LVDS_BGR_REG           | 0x0BAC | LVDS Bus Gating Reset Register           |
| LEDC_CLK_REG           | 0x0BF0 | LEDC Clock Register                      |
| LEDC_BGR_REG           | 0x0BFC | LEDC Bus Gating Reset Register           |
| CSI0_TOP_CLK_REG       | 0x0C04 | CSI0 TOP Clock Register                  |
| CSI0_0_MST_CLK_REG     | 0x0C08 | CSI0_0 Master Clock Register             |
| CSI0_1_MST_CLK_REG     | 0x0C0C | CSI0_1 Master Clock Register             |
| CSI_BGR_REG            | 0x0C1C | CSI Bus Gating Reset Register            |
| CSI_ISP_CLK_REG        | 0x0C20 | CSI ISP Clock Register                   |
| CSI_ISP_BGR_REG        | 0x0C2C | CSI ISP Bus Gating Reset Register        |
| CCU_SEC_SWITCH_REG     | 0x0F00 | CCU Security Switch Register             |
| PLL_LOCK_DBG_CTRL_REG  | 0x0F04 | PLL Lock Debug Control Register          |
| PLL_CPUX_HW_FM_REG     | 0x0F20 | PLL_CPUX Hardware FM Register            |

### 3.3.5. Register Description

#### 3.3.5.1. 0x0000 PLL\_CPUX Control Register (Default Value: 0xA00\_1000)

| Offset: 0x0000 |            |             | Register Name: PLL_CPUX_CTRL_REG                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_CPUX= InputFreq *N/P<br><b>Note: The PLL_CPUX output frequency must be in the range from 200 MHz to 3 GHz. And the default value of PLL_CPUX is 408 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                         |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                     |
| 28             | R          | 0x0         | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                              |
| 27             | R/W        | 0x1         | PLL_OUTPUT_ENABLE                                                                                                                                                                                         |

|       |     |      |                                                                                                                                                                             |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                                                               |
| 26:24 | R/W | 0x0  | PLL_LOCK_TIME.<br>PLL lock time<br>The bit indicates the step amplitude from one frequency to another.                                                                      |
| 23:18 | /   | /    | /                                                                                                                                                                           |
| 17:16 | R/W | 0x0  | PLL_OUT_EXT_DIVP<br>PLL Output External Divider P<br>00: 1<br>01: 2<br>10: 4<br>11: /<br>When output clock is less than 288MHz, clock frequency is outputted by dividing P. |
| 15:8  | R/W | 0x10 | 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:2   | /   | /    | /                                                                                                                                                                           |
| 1:0   | R/W | 0x0  | PLL_FACTOR_M<br>PLL Factor M<br>M = PLL_FACTOR_M + 1<br>PLL_FACTOR_M is from 0 to 3.<br>PLL_TestFreq=InputFreq*N/P/M.<br><b>Note: The bit is only for testing.</b>          |

### 3.3.5.2. 0x0010 PLL\_DDR Control Register (Default Value: 0x0800\_2301)

| Offset: 0x0010 |            |             | Register Name: PLL_DDR_CTRL_REG                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_DDR= InputFreq *N/M0/M1<br><b>Note: When the crystal is 24MHz, the default value of PLL_DDR is 432 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                        |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                    |
| 28             | R          | 0x0         | LOCK                                                                                                                                                     |

|       |     |      |                                                                                                                                                         |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                   |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                      |
| 26:25 | /   | /    | /                                                                                                                                                       |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0:Disable<br>1:Enable                                                                                                                 |
| 23:16 | /   | /    | /                                                                                                                                                       |
| 15:8  | R/W | 0x23 | 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:2   | /   | /    | /                                                                                                                                                       |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV_M1 +1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                      |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV_M0 +1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                  |

### 3.3.5.3. 0x0020 PLL\_PERIO Control Register (Default Value: 0x0800\_3100)

| Offset: 0x0020 |            |             | Register Name: PLL_PERIO_CTRL_REG                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                     |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_PERIO(2X) = 24MHz*N/M0/M1<br>PLL_PERIO(1X) = 24MHz*N/M0/M1/2<br><b>Note: When the crystal is 24 MHz, the default value of PLL_PERIO(2X) is 1.2 GHz. It is not recommended to modify the value.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                               |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                           |
| 28             | R          | 0x0         | LOCK                                                                                                                                                                                                                                            |

|       |     |     |                                                                                                                                                         |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                   |
| 27    | R/W | 0x1 | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                      |
| 26:16 | /   | /   | /                                                                                                                                                       |
| 15:8  | R/W | 0x1 | 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:2   | /   | /   | /                                                                                                                                                       |
| 1     | R/W | 0x0 | PLL_INPUT_DIV_M1.<br>PLL Input Div M1.<br>M1=PLL_INPUT_DIV_M1 + 1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                   |
| 0     | R/W | 0x0 | PLL_OUTPUT_DIV_M0.<br>PLL Output Div M0.<br>M0=PLL_OUTPUT_DIV_M0 + 1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                               |

### 3.3.5.4. 0x0028 PLL\_PERI1 Control Register (Default Value: 0x0800\_3100)

| Offset: 0x0028 |            |             | Register Name: PLL_PERI1_CTRL_REG                                                                                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_PERI1(2X) = InputFreq *N/M0/M1.<br>PLL_PERI1(1X) = InputFreq *N/M0/M1/2.<br><b>Note: When the crystal is 24 MHz, the default value of PLL_PERI1(2X) is 1.2 GHz. It is not recommended to modify the value.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                                           |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                       |
| 28             | R          | 0x0         | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                                                |
| 27             | R/W        | 0x1         | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable                                                                                                                                                                                                                  |

|       |     |      |                                                                                                                                                         |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | The bit is used to control the output enable of PLL.                                                                                                    |
| 26:25 | /   | /    | /                                                                                                                                                       |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                               |
| 23:16 | /   | /    | /                                                                                                                                                       |
| 15:8  | R/W | 0x31 | 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:2   | /   | /    | /                                                                                                                                                       |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV_M1 + 1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                     |
| 0     | R/W | 0x0  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV_M0 + 1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                 |

### 3.3.5.5. 0x0030 PLL\_GPU Control Register (Default Value: 0x0800\_2301)

| Offset: 0x0030 |            |             | Register Name: PLL_GPU_CTRL_REG                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_GPU0 = InputFreq *N/M0/M1.<br><b>Note: When the crystal is 24 MHz, the default value of PLL_GPU is 432 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                            |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                        |
| 28             | R          | 0x0         | LOCK<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                |
| 27             | R/W        | 0x1         | PLL_OUTPUT_ENABLE<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of PLL.                                                         |

|       |     |      |                                                                                                                                                         |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:25 | /   | /    | /                                                                                                                                                       |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                               |
| 23:16 | /   | /    | /                                                                                                                                                       |
| 15:8  | R/W | 0x23 | 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:2   | /   | /    | /                                                                                                                                                       |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV_M1 + 1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                     |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV_M0 + 1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                 |

### 3.3.5.6. 0x0040 PLL\_VIDEO0 Control Register (Default Value: 0x0800\_6203)

| Offset: 0x0040 |            |             | Register Name: PLL_VIDEO0_CTRL_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>For application,<br>PLL_VIDEO0(4X)=InputFreq *N/M<br>PLL_VIDEO0(2X)= InputFreq *N/M/2<br>PLL_VIDEO0(1X)= InputFreq *N/M/4<br><b>Note: When the crystal is 24 MHz, the default value of PLL_VIDEO0(4X) is 1188 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                                               |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                           |
| 28             | R          | 0x0         | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                                                    |
| 27             | R/W        | 0x1         | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable                                                                                                                                                                                                                      |

|       |     |      |                                                                                                                                                                                                                    |
|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | The bit is used to control the output enable of PLL.                                                                                                                                                               |
| 26:25 | /   | /    | /                                                                                                                                                                                                                  |
| 24    | R/W | 0x0  | <b>PLL_SDM_ENABLE</b><br>0: Disable<br>1: Enable                                                                                                                                                                   |
| 23:16 | /   | /    | /                                                                                                                                                                                                                  |
| 15:8  | R/W | 0x62 | <b>PLL_FACTOR_N</b><br>PLL Factor N<br>$N = \text{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:2   | /   | /    | /                                                                                                                                                                                                                  |
| 1     | R/W | 0x1  | <b>PLL_INPUT_DIV_M</b><br>PLL Input Div M<br>$M_1 = \text{PLL\_INPUT\_DIV\_M} + 1$<br>PLL_INPUT_DIV_M is from 0 to 1.                                                                                              |
| 0     | R/W | 0x1  | <b>PLL_OUTPUT_DIV_D</b><br>PLL Output Div D<br>$M_0 = \text{PLL\_OUTPUT\_DIV\_D} + 1$<br>PLL_OUTPUT_DIV_D is from 0 to 1.<br>The bit is only for testing.<br>For test, PLL_VIDEO0(4X) = $24\text{MHz} * N / M / D$ |

### 3.3.5.7. 0x0048 PLL\_VIDEO1 Control Register (Default Value: 0x0800\_6203)

| Offset: 0x0048 |            | Register Name: PLL_VIDEO1_CTRL_REG |                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex                        | Description                                                                                                                                                                                                                                                                                                                                      |
| 31             | R/W        | 0x0                                | <b>PLL_ENABLE</b><br>0: Disable<br>1: Enable<br>For application,<br>$\text{PLL\_VIDEO1}(4X) = \text{InputFreq} * N / M$ .<br>$\text{PLL\_VIDEO1}(2X) = \text{InputFreq} * N / M / 2$ .<br>$\text{PLL\_VIDEO1}(1X) = \text{InputFreq} * N / M / 4$ .<br><b>Note: When the crystal is 24 MHz, the default value of PLL_VIDEO1(4X) is 1188 MHz.</b> |
| 30             | /          | /                                  | /                                                                                                                                                                                                                                                                                                                                                |
| 29             | R/W        | 0x0                                | <b>LOCK_ENABLE</b><br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                     |
| 28             | R          | 0x0                                | <b>LOCK</b><br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                                                                                                                             |

|       |     |      |                                                                                                                                                                                                            |
|-------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                                                                         |
| 26:25 | /   | /    | /                                                                                                                                                                                                          |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                                                                                  |
| 23:16 | /   | /    | /                                                                                                                                                                                                          |
| 15:8  | R/W | 0x62 | PLL_FACTOR_N<br>PLL Factor N<br>$N = \text{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:2   | /   | /    | /                                                                                                                                                                                                          |
| 1     | R/W | 0x1  | PLL_INPUT_DIV_M<br>PLL Input Div M<br>$M1 = \text{PLL\_INPUT\_DIV\_M} + 1$<br>PLL_INPUT_DIV_M is from 0 to 1.                                                                                              |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_D<br>PLL Output Div D<br>$M0 = \text{PLL\_OUTPUT\_DIV\_D} + 1$<br>PLL_OUTPUT_DIV_D is from 0 to 1.<br>The bit is only for testing.<br>For test, PLL_VIDEO0(4X) = $24\text{MHz} * N / M / D$ |

### 3.3.5.8. 0x0050 PLL\_VIDEO2 Control Register (Default Value: 0x0800\_6203)

| Offset: 0x0050 |            |             | Register Name: PLL_VIDEO2_CTRL_REG                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>For application,<br>$\text{PLL\_VIDEO2}(4X) = \text{InputFreq} * N / M$ .<br>$\text{PLL\_VIDEO2}(2X) = \text{InputFreq} * N / M / 2$<br>$\text{PLL\_VIDEO2}(1X) = \text{InputFreq} * N / M / 4$ .<br><b>Note: When the crystal is 24 MHz, the default value of PLL_VIDEO2(4X) is 1188 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                                                                                       |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                   |

|       |     |      |                                                                                                                                                                             |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | R   | 0x0  | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                                          |
| 26:25 | /   | /    | /                                                                                                                                                                           |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                                                   |
| 23:16 | /   | /    | /                                                                                                                                                                           |
| 15:8  | R/W | 0x62 | 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:2   | /   | /    | /                                                                                                                                                                           |
| 1     | R/W | 0x1  | PLL_INPUT_DIV_M<br>PLL Input Div M<br>M1=PLL_INPUT_DIV_M +1<br>PLL_INPUT_DIV_M is from 0 to 1.                                                                              |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_D<br>PLL Output Div D<br>M0=PLL_OUTPUT_DIV_D +1<br>PLL_OUTPUT_DIV_D is from 0 to 1.<br>The bit is only for testing.<br>For test, PLL_VIDEO0(4X) =24MHz*N/M/D |

### 3.3.5.9. 0x0058 PLL\_VE Control Register (Default Value: 0x0800\_2301)

| Offset: 0x0058 |            |             | Register Name: PLL_VE_CTRL_REG                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>The PLL_VE = InputFreq *N/M0/M1.<br><b>Note: When the crystal is 24 MHz, the default value of PLL_VE is 432 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                             |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                         |

|       |     |      |                                                                                                                                                          |
|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | R   | 0x0  | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                             |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                       |
| 26:25 | /   | /    | /                                                                                                                                                        |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                                |
| 23:16 | /   | /    | /                                                                                                                                                        |
| 15:8  | R/W | 0x23 | 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:2   | /   | /    | /                                                                                                                                                        |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV_M1 +1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                       |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV_M0 + 1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                  |

### 3.3.5.10. 0x0060 PLL\_COM Control Register (Default Value: 0x0800\_2301)

| Offset: 0x0060 |            |             | Register Name: PLL_COM_CTRL_REG                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>PLL_COM = InputFreq *N/M0/M1.<br><b>Note: When the crystal is 24 MHz, the default value of PLL_COM is 432 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                           |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                       |
| 28             | R          | 0x0         | LOCK                                                                                                                                                        |

|       |     |      |                                                                                                                                                         |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                    |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                      |
| 26:25 | /   | /    | /                                                                                                                                                       |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                               |
| 23:16 | /   | /    | /                                                                                                                                                       |
| 15:8  | R/W | 0x23 | 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:2   | /   | /    | /                                                                                                                                                       |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>M1=PLL_INPUT_DIV_M1 +1<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                      |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>M0=PLL_OUTPUT_DIV_M0 +1<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                  |

### 3.3.5.11. 0x0068 PLL\_VIDEO3 Control Register (Default Value: 0x0800\_6203)

| Offset: 0x0068 |            |             | Register Name: PLL_VIDEO3_CTRL_REG                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>For application,<br>PLL_VIDEO3(4X)=InputFreq*N/M<br>PLL_VIDEO3(2X)=InputFreq*N/M/2<br>PLL_VIDEO3(1X)= InputFreq*N/M/4<br><b>Note: When the crystal is 24 MHz, the default value of PLL_VIDEO3(4X) is 1188 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                                           |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                       |

|       |     |      |                                                                                                                                                                             |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | R   | 0x0  | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                                          |
| 26:25 | /   | /    | /                                                                                                                                                                           |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>0: Disable<br>1: Enable                                                                                                                                   |
| 23:16 | /   | /    | /                                                                                                                                                                           |
| 15:8  | R/W | 0x62 | 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:2   | /   | /    | /                                                                                                                                                                           |
| 1     | R/W | 0x1  | PLL_INPUT_DIV_M<br>PLL Input Div M<br>M1=PLL_INPUT_DIV_M +1<br>PLL_INPUT_DIV_M is from 0 to 1.                                                                              |
| 0     | R/W | 0x1  | PLL_OUTPUT_DIV_D<br>PLL Output Div D<br>M0=PLL_OUTPUT_DIV_D +1<br>PLL_OUTPUT_DIV_D is from 0 to 1.<br>The bit is only for testing.<br>For test, PLL_VIDEO0(4X) =24MHz*N/M/D |

### 3.3.5.12. 0x0078 PLL\_AUDIO Control Register (Default Value: 0x0814\_5500)

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO_CTRL_REG                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                  |
| 31             | R/W        | 0x0         | PLL_ENABLE<br>0: Disable<br>1: Enable<br>This PLL is for Audio.<br>PLL_AUDIO(4X) = 24MHz*N/M0/M1/P<br><b>7.5≤N/M0/M1≤125 and 12≤N</b><br><b>The range of 24MHz*N/M0/M1 is from 180 MHz to 3 GHz.</b><br><b>The default value of PLL_AUDIO(4X) is 98 MHz.</b> |
| 30             | /          | /           | /                                                                                                                                                                                                                                                            |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable                                                                                                                                                                                                                                   |

|       |     |      |                                                                                                                                                                      |
|-------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 0: Disable<br>1: Enable                                                                                                                                              |
| 28    | R   | 0x0  | LOCK<br>0:Unlocked<br>1: Locked (It indicates that the PLL has been stable.)<br><b>Note: The bit is only valid when the bit29 is set to 1.</b>                       |
| 27    | R/W | 0x1  | PLL_OUTPUT_ENABLE<br>0:Disable<br>1:Enable<br>The bit is used to control the output enable of PLL.                                                                   |
| 26:25 | /   | /    | /                                                                                                                                                                    |
| 24    | R/W | 0x0  | PLL_SDM_ENABLE<br>Spread Spectrum and Decimal Frequency Division<br>0: Disable<br>1: Enable                                                                          |
| 23:22 | /   | /    | /                                                                                                                                                                    |
| 21:16 | R/W | 0x14 | PLL_POST_DIV_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_FACTOR_N<br>PLL Factor N<br>$N = \text{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:2   | /   | /    | /                                                                                                                                                                    |
| 1     | R/W | 0x0  | PLL_INPUT_DIV_M1<br>PLL Input Div M1<br>$M1 = \text{PLL\_INPUT\_DIV\_M1} + 1$<br>PLL_INPUT_DIV_M1 is from 0 to 1.                                                    |
| 0     | R/W | 0x0  | PLL_OUTPUT_DIV_M0<br>PLL Output Div M0<br>$M0 = \text{PLL\_OUTPUT\_DIV\_M0} + 1$<br>PLL_OUTPUT_DIV_M0 is from 0 to 1.                                                |

### 3.3.5.13. 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_DELTA_PAT_EN<br>Sigma-Delta Pattern Enable |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode         |

|       |     |     |                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 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 Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

### 3.3.5.14. 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                            |
| 23:21          | /          | /           | /                                    |
| 20             | R/W        | 0x0         | FRAC_EN                              |
| 19:17          | /          | /           | /                                    |
| 16:0           | R/W        | 0x0         | FRAC_IN                              |

### 3.3.5.15. 0x0120 PLL\_PERIO Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0120 |            |             | Register Name: PLL_PERIO_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) |

|       |     |     |                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 11: Triangular(nbit)                                                                                                       |
| 28:20 | R/W | 0x0 | WAVE_STEP<br>Wave Step                                                                                                     |
| 19    | R/W | 0x0 | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

### 3.3.5.16. 0x0124 PLL\_PERIO Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: PLL_PERIO_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:25          | /          | /           | /                                      |
| 24             | R/W        | 0x0         | DITHER_EN                              |
| 23:21          | /          | /           | /                                      |
| 20             | R/W        | 0x0         | FRAC_EN                                |
| 19:17          | /          | /           | /                                      |
| 16:0           | R/W        | 0x0         | FRAC_IN                                |

### 3.3.5.17. 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: DC=0<br>01: DC=1<br>10: Triangular(1 bit)<br>11: Triangular(n bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                           |

|       |     |     |                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------|
| 19    | R/W | 0x0 | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

### 3.3.5.18. 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          | /          | /           | /                                      |
| 24             | R/W        | 0x0         | DITHER_EN                              |
| 23:21          | /          | /           | /                                      |
| 20             | R/W        | 0x0         | FRAC_EN                                |
| 19:17          | /          | /           | /                                      |
| 16:0           | R/W        | 0x0         | FRAC_IN                                |

### 3.3.5.19. 0x0130 PLL\_GPU0 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: PLL_GPU0_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(1 bit)<br>11: Triangular(n bit) |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                           |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz                                                                     |

|       |     |     |                                                                               |
|-------|-----|-----|-------------------------------------------------------------------------------|
|       |     |     | 1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b>    |
| 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                                                       |

### 3.3.5.20. 0x0134 PLL\_GPU0 Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: PLL_GPU0_PAT1_CTRL_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:25          | /          | /           | /                                     |
| 24             | R/W        | 0x0         | DITHER_EN                             |
| 23:21          | /          | /           | /                                     |
| 20             | R/W        | 0x0         | FRAC_EN                               |
| 19:17          | /          | /           | /                                     |
| 16:0           | R/W        | 0x0         | FRAC_IN                               |

### 3.3.5.21. 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: DC=0<br>01: DC=1<br>10: Triangular(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 18:17          | R/W        | 0x0         | FREQ                                                                                                                       |

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

### 3.3.5.22. 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                               |
| 23:21          | /          | /           | /                                       |
| 20             | R/W        | 0x0         | FRAC_EN                                 |
| 19:17          | /          | /           | /                                       |
| 16:0           | R/W        | 0x0         | FRAC_IN                                 |

### 3.3.5.23. 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: DC=0<br>01: DC=1<br>10: Triangular(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz                                                                            |

|      |     |     |                            |
|------|-----|-----|----------------------------|
|      |     |     | 10: 32.5 kHz<br>11: 33 kHz |
| 16:0 | R/W | 0x0 | WAVE_BOT<br>Wave Bottom    |

### 3.3.5.24. 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                               |
| 23:21          | /          | /           | /                                       |
| 20             | R/W        | 0x0         | FRAC_EN                                 |
| 19:17          | /          | /           | /                                       |
| 16:0           | R/W        | 0x0         | FRAC_IN                                 |

### 3.3.5.25. 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: DC=0<br>01: DC=1<br>10: Triangular(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                                   |

|  |  |  |             |
|--|--|--|-------------|
|  |  |  | Wave Bottom |
|--|--|--|-------------|

**3.3.5.26. 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                               |
| 23:21          | /          | /           | /                                       |
| 20             | R/W        | 0x0         | FRAC_EN                                 |
| 19:17          | /          | /           | /                                       |
| 16:0           | R/W        | 0x0         | FRAC_IN                                 |

**3.3.5.27. 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: DC=0<br>01: DC=1<br>10: Triangular(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

**3.3.5.28. 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                           |
| 23:21          | /          | /           | /                                   |
| 20             | R/W        | 0x0         | FRAC_EN                             |
| 19:17          | /          | /           | /                                   |
| 16:0           | R/W        | 0x0         | FRAC_IN                             |

**3.3.5.29. 0x0160 PLL\_COM Pattern0 Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x0160 |            |             | Register Name: PLL_COM_PATO_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(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

**3.3.5.30. 0x0164 PLL\_COM Pattern1 Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x0164 | Register Name: PLL_COM_PAT1_CTRL_REG |
|----------------|--------------------------------------|
|----------------|--------------------------------------|

| Bit   | Read/Write | Default/Hex | Description |
|-------|------------|-------------|-------------|
| 31:25 | /          | /           | /           |
| 24    | R/W        | 0x0         | DITHER_EN   |
| 23:21 | /          | /           | /           |
| 20    | R/W        | 0x0         | FRAC_EN     |
| 19:17 | /          | /           | /           |
| 16:0  | R/W        | 0x0         | FRAC_IN     |

### 3.3.5.31. 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_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:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

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

|       |     |     |         |
|-------|-----|-----|---------|
| 23:21 | /   | /   | /       |
| 20    | R/W | 0x0 | FRAC_EN |
| 19:17 | /   | /   | /       |
| 16:0  | R/W | 0x0 | FRAC_IN |

### 3.3.5.33. 0x0178 PLL\_AUDIO Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0178 |            |             | Register Name: PLL_AUDIO_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(1 bit)<br>11: Triangular(n bit)           |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                     |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When PLL_INPUT_DIV_M1 is 1, the bit is set to 1.</b> |
| 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                                                                                                    |

### 3.3.5.34. 0x017C PLL\_AUDIO Pattern1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x017C |            |             | Register Name: PLL_AUDIO_PAT1_CTRL_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:25          | /          | /           | /                                      |
| 24             | R/W        | 0x0         | DITHER_EN                              |
| 23:21          | /          | /           | /                                      |
| 20             | R/W        | 0x0         | FRAC_EN                                |
| 19:17          | /          | /           | /                                      |

|      |     |     |         |
|------|-----|-----|---------|
| 16:0 | R/W | 0x0 | FRAC_IN |
|------|-----|-----|---------|

### 3.3.5.35. 0x300 PLL\_CPUX Bias Register (Default Value: 0x8010\_0000)

| Offset: 0x0300 |            |             | Register Name: PLL_CPUX_BIAS_REG                            |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31             | R/W        | 0x1         | VCO_RST<br>VCO reset in                                     |
| 30:21          | /          | /           | /                                                           |
| 20:16          | R/W        | 0x10        | PLL_BIAS_CURRENT<br>PLL current bias control [4:0], CPU_CP. |
| 15:0           | /          | /           | /                                                           |

### 3.3.5.36. 0x0310 PLL\_DDR0 Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0310 |            |             | Register Name: PLL_DDR0_BIAS_REG          |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:21          | /          | /           | /                                         |
| 20:16          | R/W        | 0x3         | PLL_BIAS_CTRL.<br>PLL bias control [4:0]. |
| 15:0           | /          | /           | /                                         |

### 3.3.5.37. 0x0320 PLL\_PERIO Bias Register (Default Value: 0x0003\_0000)

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

### 3.3.5.38. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

**3.3.5.39. 0x0330 PLL\_GPU0 Bias Register (Default Value: 0x0003\_0000)**

| Offset: 0x0330 |            |             | Register Name: PLL_GPU0_BIAS_REG        |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:21          | /          | /           | /                                       |
| 20:16          | R/W        | 0x3         | PLL_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

**3.3.5.40. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

**3.3.5.41. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

**3.3.5.42. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

**3.3.5.43. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0  | /   | /   | /                                       |

### 3.3.5.44. 0x0360 PLL\_COM Bias Register (Default Value: 0x0003\_0000)

| Offset: 0x0360 |            |             | Register Name: PLL_COM_BIAS_REG         |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:21          | /          | /           | /                                       |
| 20:16          | R/W        | 0x3         | PLL_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

### 3.3.5.45. 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_BIAS_CTRL<br>PLL bias control [4:0] |
| 15:0           | /          | /           | /                                       |

### 3.3.5.46. 0x0378 PLL\_AUDIO Bias Register (Default Value: 0x0003\_0000)

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

### 3.3.5.47. 0x0400 PLL\_CPUX Tuning Register (Default Value: 0x4440\_4000)

| Offset: 0x0400 |            |             | Register Name: PLL_CPUX_TUN_REG         |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31             | /          | /           | /                                       |
| 30:28          | R/W        | 0x4         | VCO_RNG_CTRL<br>VCO range control [2:0] |
| 27             | /          | /           | /                                       |

|       |     |      |                                                |
|-------|-----|------|------------------------------------------------|
| 26:24 | R/W | 0x4  | KVCO_GAIN_CTRL<br>KVCO gain control [2:0]      |
| 23    | /   | /    | /                                              |
| 22:16 | R/W | 0x40 | CNT_INIT_CTRL<br>Counter initial control [6:0] |
| 15    | R/W | 0x0  | C_OD0<br>C-REG-OD0 for verify                  |
| 14:8  | R/W | 0x40 | C_B_IN<br>C-B-IN [6:0] for verify              |
| 7     | R/W | 0x0  | C_OD1<br>C-REG-OD1 for verify                  |
| 6:0   | RO  | 0x0  | C_B_OUT<br>C-B-OUT [6:0] for verify            |

### 3.3.5.48. 0x0500 CPUX\_AXI Configuration Register (Default Value: 0x0000\_0301)

| Offset: 0x0500 |            |             | Register Name: CPUX_AXI_CFG_REG                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                  |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                            |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: RTC_32K<br>010: RC16M<br>011: PLL_CPUX<br>100: PLL_PERIO(1X)<br>101: reserved<br>110: reserved<br>111: reserved<br>CPUX Clock = Clock Source<br>CPUX_AXI Clock = Clock Source/M<br>CPUX_APB Clock = Clock Source/N |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                                                            |
| 9:8            | R/W        | 0x3         | CPUX_APB_FACTOR_N<br>Factor N.(N = FACTOR_N +1)<br>FACTOR_N is from 0 to 3.                                                                                                                                                                                                  |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                            |
| 1:0            | R/W        | 0x1         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 3.                                                                                                                                                                                                            |

**3.3.5.49. 0x0510 PSI\_AHB1\_AHB2 Configuration Register (Default Value: 0x0000\_0000)**

| Offset: 0x0510 |            |             | Register Name: PSI_AHB1_AHB2_CFG_REG                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
| 31:27          | /          | /           | /                                                                                                                                                                    |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: RTC_32K<br>010: RC16M<br>011: PLL_PERIO(1X)<br>100: PLL_PERIO(2X)<br>PSI_AHB1_AHB2 CLK = Clock Source/M/N. |
| 23:10          | /          | /           | /                                                                                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N.<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                            |
| 7:2            | /          | /           | /                                                                                                                                                                    |
| 1:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 3.                                                                                                    |

**3.3.5.50. 0x051C AHB3 Configuration Register (Default Value: 0x0000\_0000)**

| Offset: 0x051C |            |             | Register Name: AHB3_CFG_REG                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 31:27          | /          | /           | /                                                                                                                                                                     |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: RTC_32K<br>010: PSI<br>011: PLL_PERIO(1X)<br>100: PLL_PERIO(2X)<br>Other: /<br>AHB3 CLK = Clock Source/M/N. |
| 23:10          | /          | /           | /                                                                                                                                                                     |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2                                                                                                                                |

|     |     |     |                                                                   |
|-----|-----|-----|-------------------------------------------------------------------|
|     |     |     | 10: 4<br>11: 8                                                    |
| 7:2 | /   | /   | /                                                                 |
| 1:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 3. |

### 3.3.5.51. 0x0520 APB1 Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0520 |            |             | Register Name: APB1_CFG_REG                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 31:27          | /          | /           | /                                                                                                                                                                     |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: RTC_32K<br>010: PSI<br>011: PLL_PERIO(1X)<br>100: PLL_PERIO(2X)<br>Other: /<br>APB1 CLK = Clock Source/M/N. |
| 23:10          | /          | /           | /                                                                                                                                                                     |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                              |
| 7:2            | /          | /           | /                                                                                                                                                                     |
| 1:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 3.                                                                                                     |

### 3.3.5.52. 0x0524 APB2 Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0524 |            |             | Register Name: APB2_CFG_REG                                       |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31:27          | /          | /           | /                                                                 |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: RTC_32K |

|       |     |     |                                                                                                  |
|-------|-----|-----|--------------------------------------------------------------------------------------------------|
|       |     |     | 010: PSI<br>011: PLL_PERIO(1X)<br>100: PLL_PERIO(2X)<br>Other: /<br>APB2 CLK = Clock Source/M/N. |
| 23:10 | /   | /   | /                                                                                                |
| 9:8   | R/W | 0x0 | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                         |
| 7:2   | /   | /   | /                                                                                                |
| 1:0   | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 3.                                |

### 3.3.5.53. 0x0540 MBUS Configuration Register (Default Value: 0xC000\_0000)

| Offset: 0x0540 |            |             | Register Name: MBUS_CFG_REG                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31             | R/W        | 0x1         | 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:26          | /          | /           | /                                                                                                         |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL_DDR<br>10: PLL_PERIO(1X)<br>11: PLL_PERIO(2X) |
| 23:3           | /          | /           | /                                                                                                         |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 7.                                         |

### 3.3.5.54. 0x0600 DE0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0600 |            |             | Register Name: DE0_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>SCLK = Clock Source/M. |
| 30:25          | /          | /           | /                                                                                                  |
| 24             | R/W        | 0x0         | CLK_SRC_SEL.<br>Clock Source Select<br>0: PLL_COM<br>1: PLL_PERIO(2X)                              |
| 23:4           | /          | /           | /                                                                                                  |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                 |

### 3.3.5.55. 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         | DE0_RST<br>DE0 Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | DE0_GATING<br>Gating Clock For DE0<br>0: Mask<br>1: Pass |

### 3.3.5.56. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF |

|       |     |     |                                                                                                                                                           |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: Clock is ON<br>SCLK = Clock Source/M.                                                                                                                  |
| 30:27 | /   | /   | /                                                                                                                                                         |
| 26:24 | R/W | 0x0 | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_COM<br>001: PLL_PERIO(2X)<br>010: PLL_VIDEO0(2X)<br>011: PLL_VIDEO1(2X)<br>100: PLL_VIDEO2(2X)<br>Other: / |
| 23:4  | /   | /   | /                                                                                                                                                         |
| 3:0   | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                                                        |

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

### 3.3.5.58. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M. |
| 30:25          | /          | /           | /                                                                                                  |
| 24             | R/W        | 0x0         | CLK_SRC_SEL                                                                                        |

|      |     |     |                                                                   |
|------|-----|-----|-------------------------------------------------------------------|
|      |     |     | Clock Source Select<br>0: PLL_GPU0<br>1: /                        |
| 23:3 | /   | /   | /                                                                 |
| 2:0  | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 7. |

### 3.3.5.59. 0x067C GPU Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x067C |            |             | Register Name: GPU_BGR_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<br>1: Pass |

### 3.3.5.60. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N. |
| 30:25          | /          | /           | /                                                                                                    |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: OSC24M<br>1: PLL_PERIO(2X)                                  |
| 23:10          | /          | /           | /                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2                                                               |

|     |     |     |                                                                    |
|-----|-----|-----|--------------------------------------------------------------------|
|     |     |     | 10: 4<br>11: 8                                                     |
| 7:4 | /   | /   | /                                                                  |
| 3:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |

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

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

### 3.3.5.62. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/Divider M. |
| 30:25          | /          | /           | /                                                                                                          |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: PLL_VE<br>1: PLL_PERIO(2X)                                        |
| 23:3           | /          | /           | /                                                                                                          |
| 2:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 7.                                          |

**3.3.5.63. 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<br>Gating Clock for VE<br>0: Mask<br>1: Pass |

**3.3.5.64. 0x070C DMA Bus Gating Reset Register (Default Value: 0x0000\_0000)**

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

**3.3.5.65. 0x071C MSGBOX Bus Gating Reset Register (Default Value: 0x0000\_0000)**

| Offset: 0x071C |            |             | Register Name: MSGBOX_BGR_REG                           |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:17          | /          | /           | /                                                       |
| 16             | R/W        | 0x0         | MSGBOX_RST<br>MSGBOX Reset<br>0: Assert<br>1: De-assert |
| 15:1           | /          | /           | /                                                       |
| 0              | R/W        | 0x0         | MSGBOX_GATING<br>Gating Clock for MSGBOX                |

|  |  |  |                    |
|--|--|--|--------------------|
|  |  |  | 0: Mask<br>1: Pass |
|--|--|--|--------------------|

### 3.3.5.66. 0x072C SPINLOCK Bus Gating Reset Register (Default: 0x0000\_0000)

| Offset: 0x072C |            |             | Register Name: SPINLOCK_BGR_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:17          | /          | /           | /                                                                  |
| 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 |

### 3.3.5.67. 0x073C HSTIMER Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x073C |            |             | Register Name: HSTIMER_BGR_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:17          | /          | /           | /                                                                |
| 16             | R/W        | 0x0         | HSTIMER_RST<br>HSTIMER Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                |
| 0              | R/W        | 0x0         | HSTIMER_GATING<br>Gating Clock for HSTIMER<br>0: Mask<br>1: Pass |

### 3.3.5.68. 0x0740 AVS Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0740 |            |             | Register Name: AVS_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 |

|      |   |   |                |
|------|---|---|----------------|
|      |   |   | SCLK = OSC24M. |
| 30:0 | / | / | /              |

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

### 3.3.5.70. 0x079C PSI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x079C |            |             | Register Name: PSI_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | PSI_RST<br>PSI Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | PSI_GATING<br>Gating Clock for PSI<br>0: Mask<br>1: Pass |

### 3.3.5.71. 0x07AC PWM Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x07AC |            |             | Register Name: PWM_BGR_REG        |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:17          | /          | /           | /                                 |
| 16             | R/W        | 0x0         | PWM_RST<br>PWM Reset<br>0: Assert |

|      |     |     |                                                          |
|------|-----|-----|----------------------------------------------------------|
|      |     |     | 1: De-assert                                             |
| 15:1 | /   | /   | /                                                        |
| 0    | R/W | 0x0 | PWM_GATING<br>Gating Clock for PWM<br>0: Mask<br>1: Pass |

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

### 3.3.5.73. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M.                                                                                    |
| 30             | R/W        | 0x0         | MODULE_RST<br>Module Reset<br>0: Assert<br>1: De-assert                                                                                                                               |
| 29:28          | /          | /           | /                                                                                                                                                                                     |
| 27             | R/WAC      | 0x0         | SDRCLK_UPD<br>SDRCLK Configuration 0 update.<br>0: Invalid<br>1: Valid<br>Setting this bit will validate Configuration 0. It will be auto cleared after the Configuration 0 is valid. |
| 26             | /          | /           | /                                                                                                                                                                                     |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_DDR<br>01: PLL_PERI1(2X)                                                                                                                |

|      |     |     |                                                                    |
|------|-----|-----|--------------------------------------------------------------------|
|      |     |     | Other: /                                                           |
| 23:5 | /   | /   | /                                                                  |
| 4:0  | R/W | 0x3 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 31. |

### 3.3.5.74. 0x0804 MBUS Master Clock Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0804 |            |             | Register Name: MBUS_MAT_CLK_GATING_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:11          | /          | /           | /                                                                      |
| 10             | R/W        | 0x0         | G2D_MCLK_GATING<br>Gating MBUS Clock for G2D<br>0: Mask<br>1: Pass     |
| 9              | R/W        | 0x0         | ISP_MCLK_GATING<br>Gating MBUS Clock for ISP<br>0: Mask<br>1: Pass     |
| 8              | R/W        | 0x0         | CSI0_MCLK_GATING<br>Gating MBUS Clock for CSI0<br>0: Mask<br>1: Pass   |
| 7:6            | /          | /           | /                                                                      |
| 5              | R/W        | 0x0         | NAND0_MCLK_GATING<br>Gating MBUS Clock for NAND0<br>0: Mask<br>1: Pass |
| 4:3            | /          | /           | /                                                                      |
| 2              | R/W        | 0x0         | CE_MCLK_GATING<br>Gating MBUS Clock for CE<br>0: Mask<br>1: Pass       |
| 1              | R/W        | 0x0         | VE_MCLK_GATING<br>Gating MBUS Clock for VE<br>0: Mask<br>1: Pass       |
| 0              | R/W        | 0x0         | DMA_MCLK_GATING<br>Gating MBUS Clock for DMA<br>0: Mask<br>1: Pass     |



#### NOTE

DE MCLK is put in DE module to control.

**3.3.5.75. 0x080C DRAM Bus Gating Reset Register (Default Value: 0x0000\_0000)**

| 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        | 0x0         | DRAM_GATING<br>Gating Clock for DRAM<br>0: Mask<br>1: Pass |

**3.3.5.76. 0x0810 NAND0\_0 Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0810 |            |             | Register Name: NAND0_0_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>SCLK = Clock Source/M/N.                                                |
| 30:27          | /          | /           | /                                                                                                                                                    |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL.<br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERI0(1X)<br>010: PLL_PERI1(1X)<br>011: PLL_PERI0(2X)<br>100: PLL_PERI1(2X)<br>1XX: / |
| 23:10          | /          | /           | /                                                                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N.<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                            |
| 7:4            | /          | /           | /                                                                                                                                                    |

|     |     |     |                                                                    |
|-----|-----|-----|--------------------------------------------------------------------|
| 3:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |
|-----|-----|-----|--------------------------------------------------------------------|

### 3.3.5.77. 0x0814 NAND0\_1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0814 |            |             | Register Name: NAND0_1_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>SCLK = Clock Source/N/M.                                               |
| 30:27          | /          | /           | /                                                                                                                                                   |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERI0(1X)<br>010: PLL_PERI1(1X)<br>011: PLL_PERI0(2X)<br>100: PLL_PERI1(2X)<br>1XX: / |
| 23:10          | /          | /           | /                                                                                                                                                   |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                            |
| 7:4            | /          | /           | /                                                                                                                                                   |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                                                  |

### 3.3.5.78. 0x082C NAND Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x082C |            |             | Register Name: NAND_BGR_REG           |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:17          | /          | /           | /                                     |
| 16             | R/W        | 0x0         | NAND0_RST<br>NAND0 Reset<br>0: Assert |

|      |     |     |                                                              |
|------|-----|-----|--------------------------------------------------------------|
|      |     |     | 1: De-assert                                                 |
| 15:1 | /   | /   | /                                                            |
| 0    | R/W | 0x0 | NAND0_GATING<br>Gating Clock for NAND0<br>0: Mask<br>1: Pass |

### 3.3.5.79. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N. |
| 30:26          | /          | /           | /                                                                                                    |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL_PERI0(2X)<br>10: PLL_PERI1(2X)<br>11: /  |
| 23:10          | /          | /           | /                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                             |
| 7:4            | /          | /           | /                                                                                                    |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                   |

### 3.3.5.80. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF |

|       |     |     |                                                                                                     |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------|
|       |     |     | 1: Clock is ON<br>SCLK = Clock Source/M/N.                                                          |
| 30:26 | /   | /   | /                                                                                                   |
| 25:24 | R/W | 0x0 | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL_PERI0(2X)<br>10: PLL_PERI1(2X)<br>11: / |
| 23:10 | /   | /   | /                                                                                                   |
| 9:8   | R/W | 0x0 | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                            |
| 7:4   | /   | /   | /                                                                                                   |
| 3:0   | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                  |

### 3.3.5.81. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N. |
| 30:26          | /          | /           | /                                                                                                    |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL_PERI0(2X)<br>10: PLL_PERI1(2X)<br>11: /  |
| 23:10          | /          | /           | /                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                             |

|     |     |     |                                                                    |
|-----|-----|-----|--------------------------------------------------------------------|
| 7:4 | /   | /   | /                                                                  |
| 3:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |

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

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

| Offset: 0x090C |            |             | Register Name: UART_BGR_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:21          | /          | /           | /                           |
| 20             | R/W        | 0x0         | UART4_RST                   |

|      |     |     |                                                              |
|------|-----|-----|--------------------------------------------------------------|
|      |     |     | 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        |
| 15:5 | /   | /   | /                                                            |
| 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 |

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

|                |                            |
|----------------|----------------------------|
| Offset: 0x091C | Register Name: TWI_BGR_REG |
|----------------|----------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                |
|-------|------------|-------------|------------------------------------------------------------|
| 31:20 | /          | /           | /                                                          |
| 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:4  | /          | /           | /                                                          |
| 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<br>0: Mask<br>1: Pass |
| 0     | R/W        | 0x0         | TWI0_GATING<br>Gating Clock for TWI0<br>0: Mask<br>1: Pass |

### 3.3.5.85. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON |

|       |     |     |                                                                                                                                                               |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | SCLK = Clock Source/M/N.                                                                                                                                      |
| 30:27 | /   | /   | /                                                                                                                                                             |
| 26:24 | R/W | 0x0 | <b>CLK_SRC_SEL</b><br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERI0(1X)<br>010: PLL_PERI1(1X)<br>011: PLL_PERI0(2X)<br>100: PLL_PERI1(2X)<br>Others: / |
| 23:10 | /   | /   | /                                                                                                                                                             |
| 9:8   | R/W | 0x0 | <b>FACTOR_N</b><br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                               |
| 7:4   | /   | /   | /                                                                                                                                                             |
| 3:0   | R/W | 0x0 | <b>FACTOR_M</b><br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                                                     |

### 3.3.5.86. 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         | <b>SCLK_GATING</b><br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N.                                                   |
| 30:27          | /          | /           | /                                                                                                                                                             |
| 26:24          | R/W        | 0x0         | <b>CLK_SRC_SEL</b><br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERI0(1X)<br>010: PLL_PERI1(1X)<br>011: PLL_PERI0(2X)<br>100: PLL_PERI1(2X)<br>Others: / |
| 23:10          | /          | /           | /                                                                                                                                                             |
| 9:8            | R/W        | 0x0         | <b>FACTOR_N</b><br>Factor N<br>00: 1                                                                                                                          |

|     |     |     |                                                                    |
|-----|-----|-----|--------------------------------------------------------------------|
|     |     |     | 01: 2<br>10: 4<br>11: 8                                            |
| 7:4 | /   | /   | /                                                                  |
| 3:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |

### 3.3.5.87. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N.                                                   |
| 30:27          | /          | /           | /                                                                                                                                                      |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERI0(1X)<br>010: PLL_PERI1(1X)<br>011: PLL_PERI0(2X)<br>100: PLL_PERI1(2X)<br>Others: / |
| 23:10          | /          | /           | /                                                                                                                                                      |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                               |
| 7:4            | /          | /           | /                                                                                                                                                      |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                                                     |

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

| Offset: 0x096C |            |             | Register Name: SPI_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |

|       |     |     |                                                            |
|-------|-----|-----|------------------------------------------------------------|
| 31:19 | /   | /   | /                                                          |
| 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:3  | /   | /   | /                                                          |
| 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 |

### 3.3.5.89. 0x0970 EMAC0\_25M Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0970 |            |             | Register Name: EMAC0_25M_CLK_REG                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31             | R/W        | 0x0         | EMAC0_25M_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CLK =PLL_PERIO(1X)/24=25 |
| 30             | R/W        | 0x0         | EMAC0_25M_CLK_SRC_GATING<br>Gating the Source Clock of Special Clock<br>0: Clock is OFF<br>1: Clock is ON     |
| 29:0           | /          | /           | /                                                                                                             |

**3.3.5.90. 0x097C EMAC Bus Gating Reset Register (Default Value: 0x0000\_0000)**

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

**3.3.5.91. 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         | IRRT CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CLK = Clock Source/M/N.                  |
| 30:27          | /          | /           | /                                                                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: clk32k<br>001: OSC24M<br>010: PLL_PERIO(1X)<br>011: PLL_PERI1(1X)<br>Other: / |
| 23:10          | /          | /           | /                                                                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                 |
| 7:4            | /          | /           | /                                                                                                                        |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15                                                        |

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

### 3.3.5.93. 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 Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CLK = Clock Source/M/N.                  |
| 30:27          | /          | /           | /                                                                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: clk32k<br>001: OSC24M<br>010: PLL_PERI0(1X)<br>011: PLL_PERI1(1X)<br>Other: / |
| 23:10          | /          | /           | /                                                                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                 |
| 7:4            | /          | /           | /                                                                                                                        |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                       |

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

### 3.3.5.95. 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<br>0: Mask<br>1: Pass |

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

|  |  |  |                    |
|--|--|--|--------------------|
|  |  |  | 0: Mask<br>1: Pass |
|--|--|--|--------------------|

### 3.3.5.97. 0x0A10 I2S/PCM0 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A10 |            |             | Register Name: I2SPCM0_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>SCLK = Clock Source/N.             |
| 30:26          | /          | /           | /                                                                                                              |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO(divided 5 by PLL_COM)<br>other: / |
| 23:10          | /          | /           | /                                                                                                              |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                       |
| 7:0            | /          | /           | /                                                                                                              |

### 3.3.5.98. 0x0A14 I2S/PCM1 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A14 |            |             | Register Name: I2SPCM1_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>SCLK = Clock Source/N. |
| 30:26          | /          | /           | /                                                                                                  |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /           |

|       |     |     |                                                                 |
|-------|-----|-----|-----------------------------------------------------------------|
| 23:10 | /   | /   | /                                                               |
| 9:8   | R/W | 0x0 | <b>FACTOR_N</b><br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8 |
| 7:0   | /   | /   | /                                                               |

### 3.3.5.99. 0x0A18 I2S/PCM2 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A18 |            |             | Register Name: I2SPCM2_CLK_REG                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31             | R/W        | 0x0         | <b>SCLK_GATING</b><br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/N. |
| 30:26          | /          | /           | /                                                                                                         |
| 25:24          | R/W        | 0x0         | <b>CLK_SRC_SEL</b><br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /           |
| 23:10          | /          | /           | /                                                                                                         |
| 9:8            | R/W        | 0x0         | <b>FACTOR_N</b><br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                           |
| 7:0            | /          | /           | /                                                                                                         |

### 3.3.5.100. 0x0A1C I2S/PCM3 Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A1C |            |             | Register Name: I2SPCM3_CLK_REG                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31             | R/W        | 0x0         | <b>SCLK_GATING</b><br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/N. |

|       |     |     |                                                                                          |
|-------|-----|-----|------------------------------------------------------------------------------------------|
| 30:26 | /   | /   | /                                                                                        |
| 25:24 | R/W | 0x0 | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: / |
| 23:10 | /   | /   | /                                                                                        |
| 9:8   | R/W | 0x0 | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                 |
| 7:0   | /   | /   | /                                                                                        |

### 3.3.5.101. 0x0A20 I2S/PCM Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A20 |            |             | Register Name: I2SPCM_BGR_REG                                      |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:20          | /          | /           | /                                                                  |
| 19             | R/W        | 0x0         | I2S/PCM3_RST<br>I2S/PCM3 Reset<br>0: Assert<br>1: De-assert        |
| 18             | R/W        | 0x0         | I2S/PCM2_RST<br>I2S/PCM2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | I2S/PCM1_RST<br>I2S/PCM1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | I2S/PCM0_RST<br>I2S/PCM0 Reset<br>0: Assert<br>1: De-assert        |
| 15:4           | /          | /           | /                                                                  |
| 3              | R/W        | 0x0         | I2S/PCM3_GATING<br>Gating Clock for I2S/PCM3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | I2S/PCM2_GATING<br>Gating Clock for I2S/PCM2                       |

|   |     |     |                                                                    |
|---|-----|-----|--------------------------------------------------------------------|
|   |     |     | 0: Mask<br>1: Pass                                                 |
| 1 | R/W | 0x0 | I2S/PCM1_GATING<br>Gating Clock for I2S/PCM1<br>0: Mask<br>1: Pass |
| 0 | R/W | 0x0 | I2S/PCM0_GATING<br>Gating Clock for I2S/PCM0<br>0: Mask<br>1: Pass |

### 3.3.5.102. 0x0A24 OWA Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A24 |            |             | Register Name: OWA_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>SCLK = Clock Source/N |
| 30:26          | /          | /           | /                                                                                                 |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /          |
| 23:10          | /          | /           | /                                                                                                 |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                          |
| 7:0            | /          | /           | /                                                                                                 |

### 3.3.5.103. 0x0A2C OWA Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A2C |            |             | Register Name: OWA_BGR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:17          | /          | /           | /                          |
| 16             | R/W        | 0x0         | OWA_RST<br>OWA Reset       |

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

### 3.3.5.104. 0x0A40 DMIC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A40 |            |             | Register Name: DMIC_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>SCLK = Clock Source/N |
| 30:26          | /          | /           | /                                                                                                 |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /          |
| 23:10          | /          | /           | /                                                                                                 |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                          |
| 7:0            | /          | /           | /                                                                                                 |

### 3.3.5.105. 0x0A4C DMIC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A4C |            |             | 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 |
|---|-----|-----|------------------------------------------------------------|

**3.3.5.106. 0x0A50 AUDIO CODEC DAC 1X Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0A50 |            |             | Register Name: AUDIO_CODEC_DAC_1X_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>SCLK = Clock Source/M. |
| 30:26          | /          | /           | /                                                                                                  |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /           |
| 23:4           | /          | /           | /                                                                                                  |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                 |

**3.3.5.107. 0x0A54 AUDIO CODEC ADC 1X Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0A54 |            |             | Register Name: AUDIO_CODEC_ADC_1X_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>SCLK = Clock Source/M. |
| 30:26          | /          | /           | /                                                                                                  |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /           |
| 23:4           | /          | /           | /                                                                                                  |
| 3:0            | R/W        | 0x0         | FACTOR_M                                                                                           |

|  |  |  |                                                        |
|--|--|--|--------------------------------------------------------|
|  |  |  | Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |
|--|--|--|--------------------------------------------------------|

### 3.3.5.108. 0x0A58 AUDIO CODEC 4X Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A58 |            |             | Register Name: AUDIO_CODEC_4X_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>SCLK = Clock Source/M. |
| 30:26          | /          | /           | /                                                                                                  |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO(4X)<br>01: PLL_COM_AUDIO<br>other: /           |
| 23:4           | /          | /           | /                                                                                                  |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15                                  |

### 3.3.5.109. 0x0A5C AUDIO CODEC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A5C |            |             | 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 |

### 3.3.5.110. 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         | SCLK_GATING_OHCI0<br>Gating Special Clock for OHCI0<br>0: Clock is OFF<br>1: Clock is ON                                              |
| 30    | R/W        | 0x0         | USBPHY0_RST<br>USB PHY0 Reset<br>0: Assert<br>1: De-assert                                                                            |
| 29    | R/W        | 0x0         | SCLK_GATING_USBPHY0<br>Gating Special Clock for USBPHY0<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK is from OSC24M.                  |
| 28:26 | /          | /           | /                                                                                                                                     |
| 25:24 | R/W        | 0x0         | OHCI0_12M_SRC_SEL<br>OHCI0 12M Source Select<br>00: 12M divided from OHC1_48M<br>01: 12M divided from OSC24M<br>10: LOSC<br>11: RC16M |
| 23:0  | /          | /           | /                                                                                                                                     |

### 3.3.5.111. 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                         | SCLK_GATING_OHCI1<br>Gating Special Clock for OHCI1<br>0: Clock is OFF<br>1: Clock is ON                             |
| 30             | R/W        | 0x0                         | USBPHY1_RST<br>USB PHY1 Reset<br>0: Assert<br>1: De-assert                                                           |
| 29             | R/W        | 0x0                         | SCLK_GATING_USBPHY1<br>Gating Special Clock for USBPHY1<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK is from OSC24M. |
| 28:26          | /          | /                           | /                                                                                                                    |
| 25:24          | R/W        | 0x0                         | OHCI1_12M_SRC_SEL<br>OHC1 12M Source Select<br>00: 12M divided from OHC1_48M                                         |

|      |   |   |                                                      |
|------|---|---|------------------------------------------------------|
|      |   |   | 01: 12M divided from OSC24M<br>10: LOSC<br>11: RC16M |
| 23:0 | / | / | /                                                    |

### 3.3.5.112. 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         | USBOTG_RST<br>USBOTG Reset<br>0: Assert<br>1: De-assert            |
| 23:22          | /          | /           | /                                                                  |
| 21             | R/W        | 0x0         | USBEHCI1_RST<br>USBEHCI1 Reset<br>0: Assert<br>1: De-assert        |
| 20             | R/W        | 0x0         | USBEHCIO_RST<br>USBEHCIO 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         | USBOHCIO_RST<br>USBOHCIO Reset<br>0: Assert<br>1: De-assert        |
| 15:9           | /          | /           | /                                                                  |
| 8              | R/W        | 0x0         | USBOTG_GATING<br>Gating Clock for USBOTG<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         | USBEHCIO_GATING                                                    |

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

### 3.3.5.113. 0xA9C 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 |

### 3.3.5.114. 0x0ABC DPSS\_TOPO Bus Gating Reset Register (Default Value: 0x0000\_0000)

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

**3.3.5.115. 0x0ACC DPSS\_TOP1 Bus Gating Reset Register (Default Value: 0x0000\_0000)**

| Offset: 0x0ACC |            |             | Register Name: DPSS_TOP1_BGR_REG                                     |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:17          | /          | /           | /                                                                    |
| 16             | R/W        | 0x0         | DPSS_TOP1_RST<br>DPSS_TOP1 Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                    |
| 0              | R/W        | 0x0         | DPSS_TOP1_GATING<br>Gating Clock for DPSS_TOP1<br>0: Mask<br>1: Pass |

**3.3.5.116. 0x0B24 MIPI DSI Host0 Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0B24 |            |             | Register Name: MIPI_DSI_HOST0_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>SCLK = Clock Source/M.  |
| 30:26          | /          | /           | /                                                                                                   |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL_PERIO(2X)<br>10: PLL_PERIO(1X)<br>11: / |
| 23:4           | /          | /           | /                                                                                                   |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                  |

**3.3.5.117. 0x0B4C MIPI DSI Bus Gating Reset Register (Default Value: 0x0000\_0000)**

| Offset: 0x0B4C |            |             | Register Name: MIPI_BGR_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |

|       |     |     |                                                                      |
|-------|-----|-----|----------------------------------------------------------------------|
| 31:17 | /   | /   | /                                                                    |
| 16    | R/W | 0x0 | MIPI_DSI0_RST<br>MIPI_DSI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:1  | /   | /   | /                                                                    |
| 0     | R/W | 0x0 | MIPI_DSI0_GATING<br>Gating Clock for MIPI_DSI0<br>0: Mask<br>1: Pass |

### 3.3.5.118. 0x0B60 TCON LCD0 Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0B60 |            |             | Register Name: TCON_LCD0_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>SCLK = Clock Source                                                                  |
| 30:27          | /          | /           | /                                                                                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_VIDEO0(4X)<br>001: PLL_VIDEO1(4X)<br>010: PLL_VIDEO2(4X)<br>011: PLL_VIDEO3(4X)<br>100: PLL_PERIO(2X)<br>other: / |
| 23:10          | /          | /           | /                                                                                                                                                                |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                         |
| 7:4            | /          | /           | /                                                                                                                                                                |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15.                                                                                               |

**3.3.5.119. 0x0B7C TCON LCD Bus Gating Reset Register(Default Value: 0x0000\_0000)**

| Offset: 0x0B7C |            |             | Register Name: TCON_LCD_BGR_REG                                      |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:17          | /          | /           | /                                                                    |
| 16             | R/W        | 0x0         | TCON_LCD0_RST<br>TCON_LCD0 Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                    |
| 0              | R/W        | 0x0         | TCON_LCD0_GATING<br>Gating Clock for TCON_LCD0<br>0: Mask<br>1: Pass |

**3.3.5.120. 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           | /          | /           | /                                                     |

**3.3.5.121. 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         | SCLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N |
| 30:27          | /          | /           | /                                                                                                   |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: PLL_PERIO(1X)<br>Other: /                 |
| 23:10          | /          | /           | /                                                                                                   |

|     |     |     |                                                                    |
|-----|-----|-----|--------------------------------------------------------------------|
| 9:8 | R/W | 0x0 | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8           |
| 7:4 | /   | /   | /                                                                  |
| 3:0 | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |

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

### 3.3.5.123. 0x0C04 CSI TOP Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0C04 |            |             | Register Name: CSI_TOP_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>SCLK = Clock Source/M.                        |
| 30:27          | /          | /           | /                                                                                                                         |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000:PLL_PERIO(2X)<br>001:PLL_VIDEO0(2X)<br>010:PLL_VIDEO1(2X)<br>011:PLL_VIDEO2(2X) |

|      |     |     |                                                                    |
|------|-----|-----|--------------------------------------------------------------------|
|      |     |     | 100:PLL_VIDEO3(2X)<br>Others:/                                     |
| 23:4 | /   | /   | /                                                                  |
| 3:0  | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 15. |

### 3.3.5.124. 0x0C08 CSI0\_0 Master Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0C08 |            |             | Register Name: CSI0_0_MST_CLK_REG                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31             | R/W        | 0x0         | MCLK0_GATING<br>Gating CSI Master Clock0, this clock output to external device.<br>0: Clock is OFF<br>1: Clock is ON<br>MCLK0 = Clock Source/M             |
| 30:27          | /          | /           | /                                                                                                                                                          |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: OSC24M<br>001: PLL_VIDEO2(1X)<br>010: PLL_VIDEO3(1X)<br>011: PLL_VIDEO0(1X)<br>100: PLL_VIDEO1(1X)<br>Others: / |
| 23:5           | /          | /           | /                                                                                                                                                          |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 31.                                                                                         |

### 3.3.5.125. 0x0C0C CSI0\_1 Master Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0C0C |            |             | Register Name: CSI0_1_MST_CLK_REG                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31             | R/W        | 0x0         | MCLK1_GATING<br>Gating CSI0 Master Clock1, this clock output to external device.<br>0: Clock is OFF<br>1: Clock is ON<br>MCLK0 = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                                                               |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select                                                                                                              |

|      |     |     |                                                                                                                      |
|------|-----|-----|----------------------------------------------------------------------------------------------------------------------|
|      |     |     | 000: OSC24M<br>001: PLL_VIDEO3(1X)<br>010: PLL_VIDEO0(1X)<br>011: PLL_VIDEO1(1X)<br>100: PLL_VIDEO2(1X)<br>Others: / |
| 23:5 | /   | /   | /                                                                                                                    |
| 4:0  | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 31.                                                   |

### 3.3.5.126. 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         | CSI0_RST<br>CSI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | CSI0_GATING<br>Gating Clock for CSI0<br>0: Mask<br>1: Pass |

### 3.3.5.127. 0x0C20 CSI0 ISP Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C20 |            |             | Register Name: CSI0_ISP_CLK_REG                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31             | R/W        | 0x0         | MISP_GATING<br>Gating CSI0 ISP Clock, this clock output to external device.<br>0: Clock is OFF<br>1: Clock is ON<br>MCLK0 = Clock Source/M |
| 30:27          | /          | /           | /                                                                                                                                          |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000:PLL_PERIO(2X)<br>001:PLL_VIDEO0(2X)<br>010:PLL_VIDEO1(2X)<br>011:PLL_VIDEO2(2X)                  |

|      |     |     |                                                                    |
|------|-----|-----|--------------------------------------------------------------------|
|      |     |     | 100:PLL_VIDEO3(2X)<br>Others: /                                    |
| 23:5 | /   | /   | /                                                                  |
| 4:0  | R/W | 0x0 | FACTOR_M<br>Factor M.(M= FACTOR_M +1)<br>FACTOR_M is from 0 to 31. |

### 3.3.5.128. 0x0C2C CSI ISP Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0C2C |            |             | Register Name: CSI_ISP_BGR_REG                            |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:17          | /          | /           | /                                                         |
| 16             | R/W        | 0x0         | CSI_ISP_RST<br>CSI_ISP Reset<br>0: Assert<br>1: De-assert |
| 15:0           | /          | /           | /                                                         |

### 3.3.5.129. 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 registers' 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 |



#### NOTE

If the secure bit in SID module has not been programmed, the register is invalid.

**3.3.5.130. 0x0F04 PLL Lock Debug Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x0F04 |            |             | Register Name: PLL_LOCK_DBG_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | DBG_EN<br>Debug Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 30:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 24:20          | R/W        | 0x0         | DBG_SEL<br>Debug Select<br>00000: PLL_CPU0<br>00001: /<br>00010: PLL_DDR<br>00011: /<br>00100: PLL_PERIO(2X)<br>00101: PLL_PERI1(2X)<br>00110: PLL_GPU0<br>00111: /<br>01000: PLL_VIDEO0(4X)<br>01001: PLL_VIDEO1(4X)<br>01010: PLL_VIDEO2(4X)<br>01011: PLL_VE<br>01100: PLL_COM<br>01101: PLL_VIDEO3(4X)<br>01110: /<br>01111: PLL_AUDIO<br>10000: /<br>10001: /<br>10010: /<br>10011: /<br>10100: /<br>10101: /<br>10110: /<br>10111: /<br>11000: /<br>11001: /<br>11010: /<br>Others: / |
| 19             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 18:17          | R/W        | 0x0         | UNLOCK_LEVEL<br>Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles                                                                                                                                                                                                                                                                                                                                                                                  |

|      |     |     |                                                                            |
|------|-----|-----|----------------------------------------------------------------------------|
| 16   | R/W | 0x0 | LOCK_LEVEL<br>Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles |
| 15:0 | /   | /   | /                                                                          |

### 3.3.5.131. 0x0F20 PLL\_CPUX Hardware FM Register (Default Value: 0x0000\_0000)

| Offset: 0x0F20 |            |             | Register Name: PLL_CPUX_HW_FM_REG                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                    |
| 31             | R/W        | 0x0         | PLL_CPUX_MODE<br>0:Normal Mode<br>1:Hardware FM Mode<br>In normal mode, the frequency of PLL_CPUX depends on the configuration of PLL_CPUX_CTRL_REG.<br>In hardware FM mode, PLL_CPUX uses hardware frequency modulation mode. |
| 30             | R          | 0x0         | PMU_FLAG<br>0:Unlock<br>1:Lock                                                                                                                                                                                                 |
| 29:18          | /          | /           | /                                                                                                                                                                                                                              |
| 17:16          | R/W        | 0x0         | PLL_OUT_EXT_DIV P<br>PLL Output external divider P<br>00:1<br>01:2<br>10:4<br>11: /                                                                                                                                            |
| 15:8           | R/W        | 0x0         | 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:2            | /          | /           | /                                                                                                                                                                                                                              |
| 1:0            | R/W        | 0x0         | PLL_FACTOR_M<br>PLL Factor M<br>M=PLL_FACTOR_M+1<br>PLL_FACTOR_M is from 0 to 3.<br><b>Note: M has no effect on the frequency of CPU.</b>                                                                                      |

## 3.4. BROM System

### 3.4.1. Overview

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

The BROM system divides into two parts: FEL and Media Boot. The task of FEL is to write the external data to the local NVM, the task of the Media Boot is to load an effective and legitimate BOOT0 from NVM and running.

The BROM system includes the following features:

- CPU0 boot process
- Mandatory upgrade process through SMHCO, USB
- Supports GPIO pin to select the kind of boot media to boot
- Supports GPADC to select the kind of boot media to boot
- Supports efuse to select the kind of boot media to boot
- Supports normal boot and secure boot
- Supports loading only-certified firmware
- Ensure that Secure Boot is a trusted environment

### 3.4.2. Operations and Functional Descriptions

#### 3.4.2.1. Boot Media Select

The BROM system supports the following boot media:

- SD/eMMC
- Nand Flash
- SPI NOR Flash
- SPI NAND Flash

There are three ways of Boot Select: **GPIO Pin Select**, **GPADC Select** and **eFuse Select**. On startup, the BROM will read the state of BOOT\_MODE, according to the state of BOOT\_MODE to decide which way to select the kind of boot media to boot. The BOOT\_MODE is actually the BROM\_CONFIG at efuse mapping (the lowest 2 bits of the REG[0x03006210] at the SID). Table 3-2 shows BOOT\_MODE Setting.

Table 3- 2. BOOT\_MODE Setting

| BOOT_MODE[0:1] | Boot Select Type |
|----------------|------------------|
| 00             | GPADC Select     |
| 01             | GPIO Pin Select  |
| 10             | eFuse Select     |

|    |          |
|----|----------|
| 11 | reserved |
|----|----------|

### 3.4.2.1.1. GPADC Boot Select

If the state of the BOOT\_MODE is 00, that is to choose the GPADC SELECT. Table 3-3 show GPADC Boot Select Setting.

**Table 3- 3. GPADC Boot Select Setting**

| KEY_VALUE    | Boot Select type            |
|--------------|-----------------------------|
| 0x00~0xb6    | SMHC0->MLC NAND->SLC NAND   |
| 0xb7~0x22b   | SMHC0->SLC NAND->MLC NAND   |
| 0x22c~0x3af  | SMHC0->EMMC_BOOT->EMMC_USER |
| 0x3b0~0x57b  | SMHC0->EMMC_USER->EMMC_BOOT |
| 0x57c~0x73c  | SMHC0->SPI NOR              |
| 0x73d~0x8cc  | SMHC0->SPI NAND             |
| 0x8cd~0xffff | reserved                    |

### 3.4.2.1.2. GPIO Boot Select

If the state of the BOOT\_MODE is 01, that is to choose GPIO pin. And in GPIO pin mode, there is one pin (The status of the boot select pin is the bit9 of the REG[0x03000024] at the system configuration module) to select which boot media to boot. Table 3-4 shows boot media devices in GPIO pin mode.

**Table 3- 4. GPIO Pin Boot Select Configuration**

| Pin_Boot_Select[13] | Boot Media                                  |
|---------------------|---------------------------------------------|
| 0                   | SMHC0->NAND FLASH->EMMC2->SPI NOR->SPI NAND |
| 1                   | SMHC0->EMMC2->NAND FLASH->SPI NOR->SPI NAND |

### 3.4.2.1.3. Efuse Boot Select

If the state of the BOOT\_MODE is 10, that is to choose the eFuse type. The eFuse type has one 12 bits configuration (The status of the efuse boot select pin is the bit16 to bit27 of the REG[0x03006210] at SID module), every 3 bits is divided into a group of the Boot Select, so it has four groups of boot\_select. Table 3-5 shows eFuse Boot Select Configuration.

**Table 3- 5. eFuse Boot Select Configuration**

| eFuse_Boot_Select_Cfg[11:0] | Description         |
|-----------------------------|---------------------|
| eFuse_Boot_Select[2:0]      | eFuse_Boot_Select_1 |
| eFuse_Boot_Select[5:3]      | eFuse_Boot_Select_2 |
| eFuse_Boot_Select[8:6]      | eFuse_Boot_Select_3 |
| eFuse_Boot_Select[11:9]     | eFuse_Boot_Select_4 |

Table 3-6 describes each group of the eFuse Boot Select Setting. The first group to the third group are the same settings, but the fourth group need to be careful. If eFuse\_Boot\_Select\_7 is set to 111, that means the way of the Try. The way of Try is followed by SMHC0, SMHC2, Nand Flash, SPI NOR Flash, SPI NAND Flash.

**Table 3- 6. eFuse Boot Select Setting**

| eFuse_Boot_Select_n | Boot Media                                                                                        |
|---------------------|---------------------------------------------------------------------------------------------------|
| 000                 | Try                                                                                               |
| 001                 | SLC NAND Flash                                                                                    |
| 010                 | SMHC2                                                                                             |
| 011                 | SPI NOR Flash                                                                                     |
| 100                 | SPI NAND Flash                                                                                    |
| 101                 | MLC NAND Flash                                                                                    |
| 110                 | Reserved                                                                                          |
| 111                 | The next a group of the eFuse_Boot_Select, but when the n is equal to 7, it will be a way of Try. |

### 3.4.2.2. BROM Process

In Normal boot mode, the system boot will start from CPU0. Then BROM will read the state of the FEL Pin, if the FEL Pin signal is detected pulling to high level, then the system will jump to the Fast Boot process, or jump to the mandatory upgrade process. Figure 3-6 shows the BROM Process.



**Figure 3- 6. Boot Process Diagram**

### 3.4.2.3. Secure BROM Process

The Secure BROM supports the following features:

- Supports X509 certificate
- Supports cryptographic algorithms: AES-128, SHA-256, RSA-2048, DES
- Supports OTP/eFuse

Before running Security Boot, software must check whether it has been modified or replaced, so the system will check and verify the integrity of the certificate, because the certificate has been using the RSA algorithm signature. The system also uses the Crypto Engine (CE) hardware module to accelerate the speed of encryption and decryption. Using standard cryptography ensure that the firmware images can be trusted, so the Secure BROM ensure the system security state is as expected.

### 3.4.2.4. BROM Process Description

#### 3.4.2.4.1. Mandatory Upgrade Process

When the system chooses to whether enter Mandatory Upgrade Processor, if the FEL signal is detected pulling to low level, then the system will jump to the Mandatory Upgrade Process. Figure 3-7 shows the mandatory upgrade process.



Figure 3- 7. Mandatory Upgrade Process



#### NOTE

The FEL address of the Normal BROM is 0x20.

The FEL Address of the Secure BROM is 0x64.

### 3.4.2.4.2. FEL Process

When the system chooses to enter Mandatory Upgrade Process, then the system will jump to the FEL process. Figure 3-8 shows the FEL upgrade process.



Figure 3- 8. USB FEL Process

### 3.4.2.4.3. Fast Boot Process

If the value of the Fast Boot register is not zero, the system chooses to enter the Fast Boot Process. Table 3-7 shows Fast Boot Select Setting.

**Table 3- 7. Fast Boot Select Setting**

| Reg_bit[31:28] | Boot Select Type            |
|----------------|-----------------------------|
| 1              | SMHCO->MLC NAND->SLC NAND   |
| 2              | SMHCO->EMMC_USER->EMMC_BOOT |
| 3              | SMHCO->SPI NOR              |
| 4              | SMHCO->SPI NAND             |
| 5              | SMHCO->EMMC_BOOT->EMMC_USER |
| 6              | SMHCO->SLC NAND-> MLC NAND  |
| 7              | reserved                    |



#### NOTE

The address of Fast Boot is 0x07000120.

The bit[28:0] of Fast Boot register is used to record the media information.

## 3.5. System Configuration

### 3.5.1. Overview

The system configuration module is used to configure parameter for system domain, such as SRAM, CPU, PLL, BROM, and so on.

The address range of SRAM is as follows.

| Area    | Address                   | Size                                                                                                                                                                                                                      |
|---------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRAM A1 | 0x0002 0000---0x0002 3FFF | 16 KB(Supports Byte operation, the clock source is AHB1)                                                                                                                                                                  |
| SRAM C  | 0x0002 4000---0x0004 4FFF | Borrow VE 112 KB, DE 20KB, supports Byte operation, clock source can be switched to AHB1.                                                                                                                                 |
| SRAM A2 | 0x0010 0000---0x0011 3FFF | 16 KB + 64 KB<br>0x0010 0000---0x00103FFF:<br>only store CPUS Vector Table, and only 16 addresses are valid, 0x00100100, 0x00100200...0x00100F00.<br>See Openrisc, the real space of SRAM A2 is 0x00104000---0x0011 3FFF. |

### 3.5.2. Operations and Functional Descriptions

#### 3.5.2.1. SRAM

The system SRAM includes SRAM A1 and SRAM C. The address between SRAM A1 and SRAM C is continuous.

The SRAM A1 is used in System area, the SRAM C is a memory which system borrows from specific module(such as DE, VE), only in special scene(such as BOOT, STANDBY, etc), the SRAM C will switch to system to use.

When the SRAM of the module switches to SRAM C, then the clock of the SRAM switches to AHB1, if using SRAM C, the switch needs be opened, and the bus gating of the module needs be opened, the SRAM can be accessed.

## 3.6. Timer

### 3.6.1. Overview

The timer module implements the timing and counting functions. The timer module includes timer0, timer1, watchdog and AVS0, AVS1.

The timer 0 and timer 1 are completely consistent. The timer 0 and timer 1 have the following features:

- Configurable count clock: L OSC and OSC24M. L OSC is the internal low-frequency clock or the external low-frequency clock by setting L OSC\_SRC\_SEL. The external low-frequency has much accuracy.
- Configurable 8 prescale factor
- Programmable 32-bit down timer
- Two working modes: continue mode and single count mode
- Generates an interrupt when the count is decreased to 0

The watchdog is used to transmit a reset signal to reset the entire system after an exception occurs in the system. The watchdog has the following features:

- Single clock source: OSC24M/750
- 12 initial values to configure
- Generation of timeout interrupts
- Generation of reset signal
- Watchdog restart the timing

The AVS is used to the synchronization of audio and video. The AVS module includes AVS0 and AVS1, the AVS0 and AVS1 are completely consistent. The AVS has the following features:

- Single clock source: OSC24M
- Programmable 33-bit up timer
- Initial value can be updated anytime
- 12-bit frequency divider factor
- Pause/Start function

### 3.6.2. Block Diagram



Figure 3-9. Timer Block Diagram

### 3.6.3. Operations and Functional Descriptions

#### 3.6.3.1. Timer Formula

Using Timer0 as an example.

$$T_{\text{timer0}} = \frac{\text{TMRO\_INTV\_VALUE\_REG} - \text{TMRO\_CUR\_VALUE\_REG}}{\text{TMRO\_CLK\_SRC}} \times \text{TMRO\_CLK\_PRES}$$

TMRO\_INTV\_VALUE\_REG: timer initial value;

TMRO\_CUR\_VALUE\_REG: timer current counter;

TMRO\_CLK\_SRC: timer clock source;

TMRO\_CLK\_PRES: timer clock prescale ratio.

### 3.6.3.2. Typical Application



Figure 3- 10. Timer Application Diagram

Timer, watchdog and AVS configure register by APB1 bus.

Timer and watchdog have interrupt mode.

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.

### 3.6.3.3. Function Implementation

#### 3.6.3.3.1. Timer

The timer is a 32-bit down counter, the counter value is decreased by 1 on each rising edge of the count clock. Each timer has independent interrupt.

The timer has two operating modes.

- **Continuous mode**

The bit7 of the TMRn\_CTRL\_REG is set to the continuous mode, when the count value is decreased to 0, the timer module reloads data from TMRn\_INTV\_VALUE\_REG then continues to count.

- **Single mode**

The bit7 of the TMRn\_CTRL\_REG is set to the single mode, when the count value is decreased to 0, the timer stops counting. The timer starts to count again only when a new initial value is loaded.

Each timer has a prescaler that divides the working clock frequency of each timer by 1,2,4,8,16,32,64,128.

#### 3.6.3.3.2. Watchdog

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 WDOG0\_CFG\_REG is set to 0x2, when the counter value reaches 0 and WDOG0\_IRQ\_EN\_REG is enabled, the watchdog generates an interrupt, the watchdog enters into interrupt mode.

- **Reset mode**

The WDOG0\_CFG\_REG is set to 0x1, when the counter value reaches 0, the watchdog generates a reset signal to reset the entire system.

The clock source of the watchdog is OSC24M/750. There are 12 configurable initial count values.

The watchdog can restart to count by setting the WDOG0\_CTRL\_REG: write 0xA57 to bit[12:1], then write 1 to bit[0].

### 3.6.3.3.3. AVS

The AVS is a 33-bit up counter. The counter value is increased by 1 on each rising edge of the count clock.

The AVS can be operated after its clock gating in CCU module is opened.

The AVS has an OSC24M clock source and a 12-bit division factor(N1 or N2). When the timer increases to N1 or N2 from 0, AVS counter adds 1; when the counter reaches 33-bit upper limit, the AVS will start to count from initial value again.

In counter working process, the division factor and initial counter of the AVS can be changed anytime. And the AVS can stop or start to operate counter anytime.

### 3.6.3.4. Operating Mode

#### 3.6.3.4.1. Timer Initial

- (1) Configure the timer parameters: clock source, prescale factor, working mode. The configuration of these parameters have no sequence, and can be implemented by writing **TMRn\_CTRL\_REG**.
- (2) Write the initial value: write **TMRn\_INTV\_VALUE\_REG** to provide an initial value for the timer; write the bit[1] of **TMRn\_CTRL\_REG** to load the initial value to the timer, if the bit[1] is 1, writing operation cannot perform; if is 0, this indicates successful loading.
- (3) Enable timer: write the bit[0] of **TMRn\_CTRL\_REG** to enable timer count; read **TMRn\_CUR\_VALUE\_REG** to get the current count value.

#### 3.6.3.4.2. Timer Interrupt

- (1) Enable interrupt: write corresponding interrupt enable bit of **TMR\_IRQ\_EN\_REG**, when timer counter time reaches, the corresponding interrupt generates.
- (2) After enter interrupt process, write **TMR\_IRQ\_STA\_REG** to clear the interrupt pending, and execute the process of waiting for the interrupt.
- (3) Resume the interrupt and continue to execute the interrupted process.

#### 3.6.3.4.3. Watchdog Initial

- (1) Write **WDOGO\_CFG\_REG** to configure the generation of the interrupts and the output of reset signal.
- (2) Write **WDOGO\_MODE\_REG** to configure the initial count value.
- (3) Write **WDOGO\_MODE\_REG** to enable the watchdog.

#### 3.6.3.4.4. Watchdog Interrupt

Watchdog interrupt is only used for the counter.

- (1) Write **WDOGO\_IRQ\_EN\_REG** to enable the interrupt.
- (2) After enter the interrupt process, write **WDOGO\_IRQ\_STA\_REG** to clear the interrupt pending, and execute the process of waiting for the interrupt.
- (3) Resume the interrupt and continue to execute the interrupted process.

#### 3.6.3.4.5. AVS Start/Pause

- (1) Write **AVS\_CNT\_DIV\_REG** to configure the division factor.
- (2) Write **AVS\_CNT\_REG** to configure the initial count value.
- (3) Write **AVS\_CNT\_CTL\_REG** to enable AVS counter. AVS counter can be paused at any time.

### 3.6.4. Programming Guidelines

#### 3.6.4.1. Timer

Take making a 1ms delay for an example, 24M clock source, single mode and 2 pre-scale will be selected in the instance.

```
writel(0xEE0,TMR_0_INTV);           //Set interval value  
writel(0x94, TMR_0_CTRL);          //Select Single mode, 24 MHz clock source, 2 pre-scale  
writel(readl(TMR_0_CTRL)|(1<<1), TMR_0_CTRL); //Set Reload bit  
while((readl(TMR_0_CTRL)>>1)&1);    //Waiting Reload bit turns to 0  
writel(readl(TMR_0_CTRL)|(1<<0), TMR_0_CTRL); //Enable Timer0
```

#### 3.6.4.2. Watchdog Reset

In the following instance making configurations for Watchdog: configure clock source as 24M/750, configure Interval Value as 1s and configure Watchdog Configuration as To whole system. This instance indicates that reset system after 1s.

```
writel(0x1, WDOG_CONFIG);           //To whole system  
writel(0x10, WDOG_MODE);           //Interval Value set 1s
```

```
writel(readl(WDOG_MODE)|(1<<0), WDOG_MODE); //Enable Watchdog
```

### 3.6.4.3. Watchdog Restart

In the following instance making configurations for Watchdog: configure clock source as 24M/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.

```
writel(0x1, WDOG_CONFIG); //To whole system
writel(0x10, WDOG_MODE); //Interval Value set 1s
writel(readl(WDOG_MODE)|(1<<0), WDOG_MODE); //Enable Watchdog
---other codes---
writel(readl(WDOG_CTRL)|(0xA57<<1)|(1<<0), WDOG_CTRL); //Write 0xA57 at Key Field and Restart Watchdog
```

### 3.6.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| Timer       | 0x03009000   |

| Register Name       | Offset | Description                            |
|---------------------|--------|----------------------------------------|
| TMR_IRQ_EN_REG      | 0x0000 | Timer IRQ Enable Register              |
| TMR_IRQ_STA_REG     | 0x0004 | Timer Status Register                  |
| TMR0_CTRL_REG       | 0x0010 | Timer 0 Control Register               |
| TMR0_INTV_VALUE_REG | 0x0014 | Timer 0 Interval Value Register        |
| TMR0_CUR_VALUE_REG  | 0x0018 | Timer 0 Current Value Register         |
| TMR1_CTRL_REG       | 0x0020 | Timer 1 Control Register               |
| TMR1_INTV_VALUE_REG | 0x0024 | Timer 1 Interval Value Register        |
| TMR1_CUR_VALUE_REG  | 0x0028 | Timer 1 Current Value Register         |
| WDOG_IRQ_EN_REG     | 0x00A0 | Watchdog IRQ Enable Register           |
| WDOG_IRQ_STA_REG    | 0x00A4 | Watchdog Status Register               |
| WDOG_SOFT_RST_REG   | 0x00A8 | Watchdog Software Reset Register       |
| WDOG_CTRL_REG       | 0x00B0 | Watchdog Control Register              |
| WDOG_CFG_REG        | 0x00B4 | Watchdog Configuration Register        |
| WDOG_MODE_REG       | 0x00B8 | Watchdog Mode Register                 |
| WDOG_OUTPUT_CFG_REG | 0x00BC | Watchdog Output Configuration Register |
| AVS_CNT_CTL_REG     | 0x00C0 | AVS Control Register                   |
| AVS_CNT0_REG        | 0x00C4 | AVS Counter 0 Register                 |
| AVS_CNT1_REG        | 0x00C8 | AVS Counter 1 Register                 |
| AVS_CNT_DIV_REG     | 0x00CC | AVS Divisor Register                   |

### 3.6.6. Register Description

#### 3.6.6.1. 0x0000 Timer IRQ Enable Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TMR_IRQ_EN_REG                                      |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:2           | /          | /           | /                                                                  |
| 1              | R/W        | 0x0         | TMR1_IRQ_EN<br>Timer 1 Interrupt Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | TMR0_IRQ_EN<br>Timer 0 Interrupt Enable<br>0: Disable<br>1: Enable |

#### 3.6.6.2. 0x0004 Timer IRQ Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TMR_IRQ_STA_REG                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:2           | /          | /           | /                                                                                                                                          |
| 1              | R/W1C      | 0x0         | TMR1_IRQ_PEND<br>Timer 1 IRQ Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending, timer 1 interval value is reached |
| 0              | R/W1C      | 0x0         | TMR0_IRQ_PEND<br>Timer 0 IRQ Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending, timer 0 interval value is reached |

#### 3.6.6.3. 0x0010 Timer 0 Control Register(Default Value: 0x0000\_0004)

| Offset: 0x0010 |            |             | Register Name: TMR0_CTRL_REG                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                             |
| 7              | R/W        | 0x0         | TMR0_MODE<br>Timer 0 mode<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4            | R/W        | 0x0         | TMR0_CLK_PRES                                                                                                                                                                                                 |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | Select the pre-scale of timer 0 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:2 | R/W | 0x1 | TMRO_CLK_SRC<br>00:LOSC<br>01: OSC24M<br>10: /<br>11: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | R/W | 0x0 | TMRO_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 is cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0   | R/W | 0x0 | TMRO_EN<br>Timer 0 Enable<br>0: Stop/Pause<br>1: Start<br>If the timer starts, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0", the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer starts again, and the software hopes the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

### 3.6.6.4. 0x0014 Timer 0 Interval Value Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: TMRO_INTV_VALUE_REG        |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:0           | R/W        | 0x0         | TMRO_INTV_VALUE<br>Timer 0 Interval Value |



#### NOTE

The value setting should consider the system clock and the timer clock source.

### 3.6.6.5. 0x0018 Timer 0 Current Value Register(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: TMR0_CUR_VALUE_REG                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:0           | R/W        | 0x0         | TMR0_CUR_VALUE<br>Timer 0 Current Value<br>Timer 0 current value is a 32-bit down-counter (from interval value to 0). |

### 3.6.6.6. 0x0020 Timer 1 Control Register(Default Value: 0x0000\_0004)

| Offset: 0x0020 |            |             | Register Name: TMR1_CTRL_REG                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                             |
| 7              | R/W        | 0x0         | TMR1_MODE<br>Timer 1 mode<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4            | R/W        | 0x0         | TMR1_CLK_PRES<br>Select the pre-scale of timer 1 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                                                    |
| 3:2            | R/W        | 0x1         | TMR1_CLK_SRC<br>00: LOSC<br>01: OSC24M<br>10: /<br>11: /                                                                                                                                                      |
| 1              | R/W        | 0x0         | TMR1_RELOAD<br>Timer 1 Reload<br>0: No effect<br>1: Reload timer 1 Interval value<br>After the bit is set, it can not be written again before it is cleared automatically.                                    |
| 0              | R/W        | 0x0         | TMR1_EN<br>Timer 1 Enable<br>0: Stop/Pause<br>1: Start<br>If the timer starts, it will reload the interval value to internal register, and the                                                                |

|  |  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0", the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer starts again, and the software hopes the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 3.6.6.7. 0x0024 Timer 1 Interval Value Register(Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: TMR1_INTV_VALUE_REG        |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:0           | R/W        | 0x0         | TMR1_INTV_VALUE<br>Timer 1 Interval Value |



#### NOTE

The value should consider the system clock and the timer clock source.

### 3.6.6.8. 0x0028 Timer 1 Current Value Register(Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name:TMR1_CUR_VALUE_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:0           | R/W        | 0x0         | TMR1_CUR_VALUE<br>Timer 1 Current Value<br>Timer 1 current value is a 32-bit down-counter (from interval value to 0). |

### 3.6.6.9. 0x00A0 Watchdog IRQ Enable Register(Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name:WDOG_IRQ_EN_REG                                       |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:1           | /          | /           | /                                                                   |
| 0              | R/W        | 0x0         | WDOG_IRQ_EN<br>Watchdog Interrupt Enable<br>0: Disable<br>1: Enable |

### 3.6.6.10. 0x00A4 Watchdog Status Register (Default Value: 0x0000\_0000)

|                |                                |
|----------------|--------------------------------|
| Offset: 0x00A4 | Register Name:WDOG_IRQ_STA_REG |
|----------------|--------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                   |
|------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | /          | /           | /                                                                                                                                             |
| 0    | R/W1C      | 0x0         | WDOG_IRQ_PEND<br>Watchdog IRQ Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending. Watchdog interval value is reached. |

### 3.6.6.11. Watchdog Software Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x00A8 |            |             | Register Name:WDOG_SOFT_RST_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 0 can be written with the new value.             |
| 15:1           | /          | /           | /                                                                                                                                  |
| 0              | R/W1C      | 0x0         | Soft Reset Enable<br>0: De-assert<br>1: Reset System<br>If the system is reset by the bit, the watchdog function need be disabled. |

### 3.6.6.12. 0x00B0 Watchdog Control Register(Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name:WDOG_CTRL_REG                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:13          | /          | /           | /                                                                                                                                        |
| 12:1           | R/W        | 0x0         | WDOG_KEY_FIELD<br>Watchdog Key Field<br>It should be written to 0xA57. Writing any other value in this field aborts the write operation. |
| 0              | R/W1S      | 0x0         | WDOG_RESTART<br>Watchdog Restart<br>0: No effect<br>1: Restart the Watchdog                                                              |

### 3.6.6.13. 0x00B4 Watchdog Configuration Register (Default Value: 0x0000\_0001)

| Offset: 0x00B4 |            |             | Register Name:WDOG_CFG_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:2           | /          | /           | /                          |
| 1:0            | R/W        | 0x1         | WDOG_CONFIG<br>00: /       |

|  |  |  |                                                    |
|--|--|--|----------------------------------------------------|
|  |  |  | 01: To whole system<br>10: Only interrupt<br>11: / |
|--|--|--|----------------------------------------------------|

### 3.6.6.14. 0x00B8 Watchdog Mode Register (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name:WDOG_MODE_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | <p>WDOG_INTV_VALUE<br/>                     Watchdog Interval Value<br/>                     Watchdog clock source is OSC24M/750. If the clock source is turned off, Watchdog will not work.</p> <p>0000: 16000 cycles (0.5s)<br/>                     0001: 32000 cycles (1s)<br/>                     0010: 64000 cycles (2s)<br/>                     0011: 96000 cycles (3s)<br/>                     0100: 128000 cycles (4s)<br/>                     0101: 160000 cycles (5s)<br/>                     0110: 192000 cycles (6s)<br/>                     0111: 256000 cycles (8s)<br/>                     1000: 320000 cycles (10s)<br/>                     1001: 384000 cycles (12s)<br/>                     1010: 448000 cycles (14s)<br/>                     1011: 512000 cycles (16s)<br/>                     Others: Reserved</p> |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0              | R/W        | 0x0         | <p>WDOG_EN<br/>                     Watchdog Enable<br/>                     0: Disable<br/>                     1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 3.6.6.15. Watchdog Output Config Register (Default Value: 0x0000\_001F)

| Offset: 0x00BC |            |             | Register Name:WDOG_OUTPUT_CFG_REG                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:12          | /          | /           | /                                                                                                                                                   |
| 11:0           | R/W        | 0x1F        | <p>Wdog output config<br/>                     Wdog rst valid time config<br/> <math>T=1/32ms*(N+1)</math><br/>                     Default 1ms</p> |

### 3.6.6.16. 0x00C0 AVS Counter Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: AVS_CNT_CTL_REG                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:10          | /          | /           | /                                                                                                                    |
| 9              | R/W        | 0x0         | AVS_CNT1_PS<br>Audio/Video Sync Counter 1 Pause Control<br>0: Not pause<br>1: Pause Counter 1                        |
| 8              | R/W        | 0x0         | AVS_CNT0_PS<br>Audio/Video Sync Counter 0 Pause Control<br>0: Not pause<br>1: Pause Counter 0                        |
| 7:2            | /          | /           | /                                                                                                                    |
| 1              | R/W        | 0x0         | AVS_CNT1_EN<br>Audio/Video Sync Counter 1 Enable/Disable<br>The counter source is OSC24M.<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | AVS_CNT0_EN<br>Audio/Video Sync Counter 0 Enable/Disable<br>The counter source is OSC24M.<br>0: Disable<br>1: Enable |

### 3.6.6.17. 0x00C4 AVS Counter 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: AVS_CNT0_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:0           | R/W        | 0x0         | AVS_CNT0<br>Counter 0 for Audio/Video Sync Application<br>The high 32 bits of the internal 33-bit counter register. The initial value of the internal 33-bit counter register can be set by software. The LSB bit of the 33-bit counter register should be zero when the initial value is updated. It will count from the initial value. The initial value can be updated at any time. It can also be paused by setting AVS_CNT0_PS to '1'. When it is paused, the counter will not increase. |

### 3.6.6.18. 0x00C8 AVS Counter 1 Register(Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: AVS_CNT1_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W | 0x0 | <p><b>AVS_CNT1</b></p> <p>Counter 1 for Audio/Video Sync Application</p> <p>The high 32 bits of the internal 33-bit counter register. The initial value of the internal 33-bit counter register can be set by software. The LSB bit of the 33-bit counter register should be zero when the initial value is updated. It will count from the initial value. The initial value can be updated at any time. It can also be paused by setting AVS_CNT1_PS to '1'. When it is paused, the counter will not increase.</p> |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 3.6.6.19. 0x00CC AVS Counter Divisor Register (Default Value: 0x05DB\_05DB)

| <b>Offset: 0x00CC</b> |                   |                    | <b>Register Name: AVS_CNT_DIV_REG</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------|-------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:28                 | /                 | /                  | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27:16                 | R/W               | 0x5DB              | <p><b>AVS_CNT1_D</b></p> <p>Divisor N for AVS Counter 1</p> <p>AVS CN1 CLK=24MHz/Divisor_N1.</p> <p>Divisor N1 = Bit [27:16] + 1.</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-bit counter engine will maintain another 12-bit counter. The 12-bit counter is used for counting the cycle number of one 24MHz clock. When the 12-bit counter reaches (<math>\geq</math> N) the divisor value, the internal 33-bit counter register will increase 1 and the 12-bit counter will reset to zero and restart again.</p> <p>It can be configured by software at any time.</p> |
| 15:12                 | /                 | /                  | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11:0                  | R/W               | 0x5DB              | <p><b>AVS_CNT0_D</b></p> <p>Divisor N for AVS Counter 0</p> <p>AVS CNO CLK=24MHz/Divisor_N0.</p> <p>Divisor N0 = Bit [11:0] + 1</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-bit counter engine will maintain another 12-bit counter. The 12-bit counter is used for counting the cycle number of one 24MHz clock. When the 12-bit counter reaches (<math>\geq</math> N) the divisor value, the internal 33-bit counter register will increase 1 and the 12-bit counter will reset to zero and restart again.</p> <p>It can be configured by software at any time.</p>   |

## 3.7. High Speed Timer

### 3.7.1. Overview

The high speed timer(HSTimer) module implements more precise timing and counting functions.

The HSTimer has the following features:

- Timing clock is AHB1 that can provides more precise timing clock
- Configurable 5 prescale factor
- Configurable 56-bit down timer
- Supports 2 working modes: continuous mode and single mode
- Supports test mode
- Generates an interrupt when the count is decreased to 0

### 3.7.2. Block Diagram

Figure 3-11 shows a block diagram of the HSTimer.



Figure 3- 11. HSTimer Block Diagram

### 3.7.3. Operations and Functional Descriptions

#### 3.7.3.1. HSTimer Formula

$$\frac{(HS\_TMR\_INTV\_HI\_REG << 32 + HS\_TMR\_INTV\_LO\_REG) - (HS\_TMR\_CURNT\_HI\_REG << 32 + HS\_TMR\_CURNT\_LO\_REG)}{AHB1CLK} \times HS\_TMR\_CLK$$

HS\_TMR\_INTV\_HI\_REG: Initial of Counter Higher Bit

HS\_TMR\_INTV\_LO\_REG: Initial of Counter Lower Bit

HS\_TMR\_CURNT\_HI\_REG: Current Value of Counter Higher Bit

HS\_TMR\_CURNT\_LO\_REG: Current Value of Counter Lower Bit

AHB1CLK: AHB1 Clock Frequency

HS\_TMR\_CLK: Time Prescale Ratio of Counter

### 3.7.3.2. Typical Application



Figure 3-12. HSTimer Application Diagram

The high speed timer is on AHB1, and the high speed timer controls registers by AHB1.

The high speed timer has single clock source: AHB1. The high speed timer can generate interrupt.

### 3.7.3.3. Function Implemention

The high speed timer is a 56-bit down counter, the counter value is decreased by 1 on each rising edge of the count clock.

The high speed timer has two timing modes.

- **Continuous mode** : The bit7 of **HS\_TMR0\_CTRL\_REG** is set to the continuous mode, when the count value is decreased to 0, the high speed timer module reloads data from **HS\_TMR\_INTV\_LO\_REG** and **HS\_TMR\_INTV\_HI\_REG**, then continues to count.
- **Single mode** : The bit7 of **HS\_TMR0\_CTRL\_REG** is set to the single mode, when the count value is decreased to 0, the high speed timer stops counting. The high speed timer starts to count again only when a new initial value is loaded.

The high speed timer has two operating modes.

- **Normal mode**: When the bit31 of **HS\_TMR0\_CTRL\_REG** is set to the normal mode, the high speed timer is used as 56-bit down counter, which can finish continuous timing and single timing.
- **Test mode**: When the bit31 of **HS\_TMR0\_CTRL\_REG** is set to the test mode, then **HS\_TMR\_INTV\_LO\_REG** must be set to 0x1, the high speed timer is used as 24-bit down counter, and **HS\_TMR\_INTV\_HI\_REG** is the initial value of the high speed timer.

Each high speed timer has a prescaler that divides the working clock frequency of each working timer by 1,2,4,8,16.

### 3.7.3.4. Operating Mode

#### 3.7.3.4.1. HSTimer Initial



**Figure 3- 13. HSTimer Initialization Process**

- (1) AHB1 clock management: Open the clock gating of AHB1 and de-assert the soft reset of AHB1 in CCU.
- (2) Configure the corresponding parameters of the high speed timer: clock source, prescaler factor, working mode, counting mode. These parameters that are written to **HS\_TMR0\_CTRL\_REG** have no sequences.
- (3) Write the initial value: Firstly write the low-bit register (**HS\_TMR\_INTV\_LO\_REG**), then write the high-bit register (**HS\_TMR\_INTV\_HI\_REG**). Write the bit1 of **HS\_TMR0\_CTRL\_REG** to load the initial value. If in timing stop stage of high speed timer, write the bit1 and bit0 of **HS\_TMR0\_CTRL\_REG** to reload the initial value.
- (4) Enable high speed timer: Write the bit[0] of **HS\_TMR0\_CTRL\_REG** to enable high speed timer to count.
- (5) Reading **HS\_TMR\_CURNT\_LO\_REG** and **HS\_TMR\_CURNT\_HI\_REG** can get current counting value.

#### 3.7.3.4.2. HSTimer Interrupt

- (1) Enable interrupt: Write the corresponding interrupt enable bit of **HS\_TMR\_IRQ\_EN\_REG**, when the counting time of high speed timer reaches, the corresponding interrupt generates.
- (2) After enter the interrupt process, write **HS\_TMR\_IRQ\_STAS\_REG** to clear the interrupt pending.
- (3) Resume the interrupt and continue to execute the interrupted process.

### 3.7.4. Programming Guidelines

Take making a 1us delay using HSTimer0 for an instance as follows, AHB1CLK will be configured as 100MHz and n\_mode,single mode and 2 pre-scale will be selected in this instance.

```

writel(0x32, HS_TMR0_INTV_LO);           //Set interval value Lo 0x32
writel(0x0, HS_TMR0_INTV_HI);            //Set interval value Hi 0x0
writel(0x90, HS_TMR0_CTRL);              //Select n_mode,2 pre-scale,single mode
writel(readl(HS_TMR0_CTRL)|(1<<1), HS_TMR0_CTRL); //Set Reload bit
writel(readl(HS_TMR0_CTRL)|(1<<0), HS_TMR0_CTRL); //Enable HSTimer0
  
```

```

while(!(readl(HS_TMR IRQ_STAS)&1));           //Wait for HSTimer0 to generate pending
writel(1,HS_TMR IRQ_STAS);                     //Clear HSTimer0 pending
    
```

### 3.7.5. Register List

| Module Name      | Base Address |
|------------------|--------------|
| High Speed Timer | 0x03005000   |

| Register Name        | Offset | Description                             |
|----------------------|--------|-----------------------------------------|
| HS_TMR IRQ_EN_REG    | 0x0000 | HS Timer IRQ Enable Register            |
| HS_TMR IRQ_STAS_REG  | 0x0004 | HS Timer Status Register                |
| HS_TMR0_CTRL_REG     | 0x0020 | HS Timer 0 Control Register             |
| HS_TMR0_INTV_LO_REG  | 0x0024 | HS Timer 0 Interval Value Low Register  |
| HS_TMR0_INTV_HI_REG  | 0x0028 | HS Timer 0 Interval Value High Register |
| HS_TMR0_CURNT_LO_REG | 0x002C | HS Timer 0 Current Value Low Register   |
| HS_TMR0_CURNT_HI_REG | 0x0030 | HS Timer 0 Current Value High Register  |
| HS_TMR1_CTRL_REG     | 0x0040 | HS Timer 1 Control Register             |
| HS_TMR1_INTV_LO_REG  | 0x0044 | HS Timer 1 Interval Value Low Register  |
| HS_TMR1_INTV_HI_REG  | 0x0048 | HS Timer 1 Interval Value High Register |
| HS_TMR1_CURNT_LO_REG | 0x004C | HS Timer 1 Current Value Low Register   |
| HS_TMR1_CURNT_HI_REG | 0x0050 | HS Timer 1 Current Value High Register  |

### 3.7.6. Register Description

#### 3.7.6.1. 0x0000 HS Timer IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: HS_TMR IRQ_EN_REG                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:2           | /          | /           | /                                                                                |
| 1              | R/W        | 0x0         | HS_TMR1_INT_EN<br>High Speed Timer 1 Interrupt Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | HS_TMR0_INT_EN<br>High Speed Timer 0 Interrupt Enable<br>0: Disable<br>1: Enable |

**3.7.6.2. 0x0004 HS Timer IRQ Status Register(Default Value: 0x0000\_0000)**

| Offset: 0x0004 |            |             | Register Name: HS_TMR_IRQ_STAS_REG                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:2           | /          | /           | /                                                                                                                                                                                 |
| 1              | R/W1C      | 0x0         | <p>HS_TMR1_IRQ_PEND<br/>High Speed Timer 1 IRQ Pending<br/>Setting 1 to the bit will clear it.<br/>0: No effect<br/>1: Pending, High speed timer 1 interval value is reached.</p> |
| 0              | R/W1C      | 0x0         | <p>HS_TMR0_IRQ_PEND<br/>High Speed Timer 0 IRQ Pending<br/>Setting 1 to the bit will clear it.<br/>0: No effect<br/>1: Pending, High speed timer 0 interval value is reached.</p> |

**3.7.6.3. 0x0020 HS Timer 0 Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x0020 |            |             | Register Name: HS_TMR0_CTRL_REG                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                           |
| 31             | R/W        | 0x0         | <p>HS_TMR0_TEST<br/>High Speed Timer 0 Test Mode<br/>In test mode, the low register should be set to 0x1, the high register will down counter. The counter needs to be reloaded.<br/>0: Normal mode<br/>1: Test mode</p>              |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                     |
| 7              | R/W        | 0x0         | <p>HS_TMR0_MODE<br/>High Speed Timer 0 Mode<br/>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br/>1: Single mode. When interval value reached, the timer will disable automatically.</p> |
| 6:4            | R/W        | 0x0         | <p>HS_TMR0_CLK<br/>Select the pre-scale of the high speed timer 0 clock sources.<br/>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /<br/>110: /<br/>111: /</p>                                                    |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                     |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | R/W1S | 0x0 | HS_TMR0_RELOAD<br>High Speed Timer 0 Reload<br>0: No effect<br>1: Reload High Speed Timer 0 Interval Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 | R/W   | 0x0 | HS_TMR0_EN<br>High Speed Timer 0 Enable<br>0: Stop/Pause<br>1: Start<br>If the timer starts, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0", the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer starts again, and the software hopes the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

#### 3.7.6.4. 0x0024 HS Timer 0 Interval Value Lo Register(Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: HS_TMR0_INTV_LO_REG                                |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31:0           | R/W        | 0x0         | HS_TMR0_INTV_VALUE_LO<br>High Speed Timer 0 Interval Value [31:0] |

#### 3.7.6.5. 0x0028 HS Timer 0 Interval Value Hi Register(Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: HS_TMR0_INTV_HI_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:24          | /          | /           | /                                                                  |
| 23:0           | R/W        | 0x0         | HS_TMR0_INTV_VALUE_HI<br>High Speed Timer 0 Interval Value [55:32] |



#### NOTE

The interval value register is a 56-bit register. When read or write the interval value, the Lo register should be read or written first. And the High register should be written after the Lo register.

#### 3.7.6.6. 0x002C HS Timer 0 Current Value Lo Register(Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: HS_TMR0_CURNT_LO_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R/W        | 0x0         | HS_TMR0_CUR_VALUE_LO                |

|  |  |  |                                         |
|--|--|--|-----------------------------------------|
|  |  |  | High Speed Timer 0 Current Value [31:0] |
|--|--|--|-----------------------------------------|

### 3.7.6.7. 0x0030 HS Timer 0 Current Value Hi Register(Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: HS_TMR0_CURNT_HI_REG                              |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:24          | /          | /           | /                                                                |
| 23:0           | R/W        | 0x0         | HS_TMR0_CUR_VALUE_HI<br>High Speed Timer 0 Current Value [55:32] |


**NOTE**

HS timer current value is a 56-bit down-counter (from interval value to 0).

The current value register is a 56-bit register. When read or write the current value, the Low register should be read or written first.

### 3.7.6.8. 0x0040 HS Timer 1 Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: HS_TMR1_CTRL_REG                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | HS_TMR1_TEST<br>High Speed Timer 1 Test Mode<br>In test mode, the low register should be set to 0x1, the high register will down counter. The counter needs to be reloaded.<br>0: Normal mode<br>1: Test mode               |
| 30:8           | /          | /           | /                                                                                                                                                                                                                           |
| 7              | R/W        | 0x0         | HS_TMR1_MODE<br>High Speed Timer 1 Mode<br>0: Continuous mode. When interval value reached, the timer will not disable automatically.<br>1: Single mode. When interval value reached, the timer will disable automatically. |
| 6:4            | R/W        | 0x0         | HS_TMR1_CLK<br>Select the pre-scale of the high speed timer 1 clock sources.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /<br>110: /<br>111: /                                                          |
| 3:2            | /          | /           | /                                                                                                                                                                                                                           |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | R/W1S | 0x0 | <b>HS_TMR1_RELOAD</b><br>High Speed Timer 1 Reload<br>0: No effect<br>1: Reload High Speed Timer 1 Interval Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 | R/W   | 0x0 | <b>HS_TMR1_EN</b><br>High Speed Timer 1 Enable<br>0: Stop/Pause<br>1: Start<br>If the timer starts, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0", the current value counter will pause. At least wait for 2 cycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer starts again, and the software hopes the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

### 3.7.6.9. 0x0044 HS Timer 1 Interval Value Lo Register(Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: HS_TMR1_INTV_LO_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:0           | R/W        | 0x0         | <b>HS_TMR1_INTV_VALUE_LO</b><br>High Speed Timer 1 Interval Value [31:0] |

### 3.7.6.10. 0x0048 HS Timer 1 Interval Value Hi Register(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: HS_TMR1_INTV_HI_REG                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:24          | /          | /           | /                                                                         |
| 23:0           | R/W        | 0x0         | <b>HS_TMR1_INTV_VALUE_HI</b><br>High Speed Timer 1 Interval Value [55:32] |



#### NOTE

The interval value register is a 56-bit register. When read or write the interval value, the Lo register should be read or written first. And the High register should be written after the Lo register.

### 3.7.6.11. 0x004C HS Timer 1 Current Value Lo Register(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: HS_TMR1_CURNT_LO_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R/W        | 0x0         | <b>HS_TMR1_CUR_VALUE_LO</b>         |

|  |  |  |                                         |
|--|--|--|-----------------------------------------|
|  |  |  | High Speed Timer 1 Current Value [31:0] |
|--|--|--|-----------------------------------------|

### 3.7.6.12. 0x0050 HS Timer 1 Current Value Hi Register(Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: HS_TMR1_CURNT_HI_REG                              |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:24          | /          | /           | /                                                                |
| 23:0           | R/W        | 0x0         | HS_TMR1_CUR_VALUE_HI<br>High Speed Timer 1 Current Value [55:32] |



#### NOTE

HS timer current value is a 56-bit down-counter (from interval value to 0).

The current value register is a 56-bit register. When read or write the current value, the Low register should be read or written first.

## 3.8. GIC

### 3.8.1. Interrupt Source

| Interrupt Number         | Interrupt Source | Interrupt Vector | Description      |
|--------------------------|------------------|------------------|------------------|
| 0                        | SGI 0            | 0x00             | SGI 0 interrupt  |
| 1                        | SGI 1            | 0x04             | SGI 1 interrupt  |
| 2                        | SGI 2            | 0x08             | SGI 2 interrupt  |
| 3                        | SGI 3            | 0x0C             | SGI 3 interrupt  |
| 4                        | SGI 4            | 0x10             | SGI 4 interrupt  |
| 5                        | SGI 5            | 0x14             | SGI 5 interrupt  |
| 6                        | SGI 6            | 0x18             | SGI 6 interrupt  |
| 7                        | SGI 7            | 0x1C             | SGI 7 interrupt  |
| 8                        | SGI 8            | 0x20             | SGI 8 interrupt  |
| 9                        | SGI 9            | 0x24             | SGI 9 interrupt  |
| 10                       | SGI 10           | 0x28             | SGI 10 interrupt |
| 11                       | SGI 11           | 0x2C             | SGI 11 interrupt |
| 12                       | SGI 12           | 0x30             | SGI 12 interrupt |
| 13                       | SGI 13           | 0x34             | SGI 13 interrupt |
| 14                       | SGI 14           | 0x38             | SGI 14 interrupt |
| 15                       | SGI 15           | 0x3C             | SGI 15 interrupt |
| 16                       | PPI 0            | 0x40             | PPI 0 interrupt  |
| 17                       | PPI 1            | 0x44             | PPI 1 interrupt  |
| 18                       | PPI 2            | 0x48             | PPI 2 interrupt  |
| 19                       | PPI 3            | 0x4C             | PPI 3 interrupt  |
| 20                       | PPI 4            | 0x50             | PPI 4 interrupt  |
| 21                       | PPI 5            | 0x54             | PPI 5 interrupt  |
| 22                       | PPI 6            | 0x58             | PPI 6 interrupt  |
| 23                       | PPI 7            | 0x5C             | PPI 7 interrupt  |
| 24                       | PPI 8            | 0x60             | PPI 8 interrupt  |
| 25                       | PPI 9            | 0x64             | PPI 9 interrupt  |
| 26                       | PPI 10           | 0x68             | PPI 10 interrupt |
| 27                       | PPI 11           | 0x6C             | PPI 11 interrupt |
| 28                       | PPI 12           | 0x70             | PPI 12 interrupt |
| 29                       | PPI 13           | 0x74             | PPI 13 interrupt |
| 30                       | PPI 14           | 0x78             | PPI 14 interrupt |
| 31                       | PPI 15           | 0x7C             | PPI 15 interrupt |
| <b>Normal Interfaces</b> |                  |                  |                  |
| 32                       | UART0            | 0x80             | UART0 interrupt  |
| 33                       | UART1            | 0x84             | UART1 interrupt  |
| 34                       | UART2            | 0x88             | UART2 interrupt  |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description              |
|------------------|------------------|------------------|--------------------------|
| 35               | UART3            | 0x8C             | UART3 interrupt          |
| 36               | UART4            | 0x90             | UART4 interrupt          |
| 37               | /                | 0x94             | /                        |
| 38               | /                | 0x98             | /                        |
| 39               | TWI0             | 0x9C             | TWI0 interrupt           |
| 40               | TWI1             | 0xA0             | TWI1 interrupt           |
| 41               | TWI2             | 0xA4             | TWI2 interrupt           |
| 42               | TWI3             | 0xA8             | TWI3 interrupt           |
| 43               | /                | 0xAC             | /                        |
| 44               | /                | 0xB0             | /                        |
| 45               | SPI0             | 0xB4             | SPI0 interrupt           |
| 46               | SPI1             | 0xB8             | SPI1 interrupt           |
| 47               | SPI2             | 0xBC             | SPI2 interrupt           |
| 48               | EMAC0            | 0xC0             | EMAC0 interrupt          |
| 49               | /                | 0xC4             | /                        |
| 50               | PWM              | 0xC8             | PWM interrupt            |
| 51               | IR_TX            | 0xCC             | CIR transimter interrupt |
| 52               | GPADC            | 0xD0             | GPADC interrupt          |
| 53               | THS              | 0xD4             | Thermal sensor interrupt |
| 54               | LRADC            | 0xD8             | LRADC interrupt          |
| 55               | OWA              | 0xDC             | OWA interrupt            |
| 56               | DMIC             | 0xE0             | DMIC interrupt           |
| 57               | Audio Codec      | 0xE4             | Audio codec interrupt    |
| 58               | I2S0             | 0xE8             | I2S0 interrupt           |
| 59               | I2S1             | 0xEC             | I2S1 interrupt           |
| 60               | I2S2             | 0xF0             | I2S2 interrupt           |
| 61               | I2S3             | 0xF4             | I2S3 interrupt           |
| 62               | USB0_EHCI        | 0xF8             | USB0_EHCI interrupt      |
| 63               | USB0_OHCI        | 0xFC             | USB0_OHCI interrupt      |
| 64               | USB0_OTG         | 0x100            | USB0_OTG interrupt       |
| 65               | USB1_EHCI        | 0x104            | USB1_EHCI interrupt      |
| 66               | USB1_OHCI        | 0x108            | USB1_OHCI interrupt      |
| 67               | LEDC             | 0x10C            | LEDC interrupt           |
| 68               | CIR_RX           | 0x110            | CIR receiver interrupt   |
| 69               | /                | 0x114            | /                        |
| <b>Memory</b>    |                  |                  |                          |
| 70               | NAND0            | 0x118            | NAND0 interrupt          |
| 71               | SMHC0            | 0x11C            | SMHC0 interrupt          |
| 72               | SMHC1            | 0x120            | SMHC1 interrupt          |
| 73               | SMHC2            | 0x124            | SMHC2 interrupt          |
| 74               | /                | 0x128            | /                        |
| 75               | /                | 0x12C            | /                        |

| Interrupt Number                    | Interrupt Source | Interrupt Vector | Description                        |
|-------------------------------------|------------------|------------------|------------------------------------|
| <b>System</b>                       |                  |                  |                                    |
| 76                                  | CLK_DET          | 0x130            | Clock detect interrupt             |
| 77                                  | DMA_NS           | 0x134            | DMA interrupt in non-secure domain |
| 78                                  | MSGBOX           | 0x138            | Message box interrupt              |
| 79                                  | SPINLOCK         | 0x13C            | Spinlock interrupt                 |
| 80                                  | HSTIMER0         | 0x140            | High speed timer0 interrupt        |
| 81                                  | HSTIMER1         | 0x144            | High speed timer1 interrupt        |
| 82                                  | SMC              | 0x148            | Secure memory control interrupt    |
| 83                                  | TIMER0           | 0x14C            | Timer0 interrupt                   |
| 84                                  | TIMER1           | 0x150            | Timer1 interrupt                   |
| 85                                  | WDOG             | 0x154            | Watchdog interrupt                 |
| 86                                  | GPIOB            | 0x158            | GPIOB interrupt                    |
| 87                                  | GPIOC            | 0x15C            | GPIOC interrupt                    |
| 88                                  | GPIOD            | 0x160            | GPIOD interrupt                    |
| 89                                  | GPIOE            | 0x164            | GPIOE interrupt                    |
| 90                                  | GPIOF            | 0x168            | GPIOF interrupt                    |
| 91                                  | GPIOG            | 0x16C            | GPIOG interrupt                    |
| 92                                  | GPIOH            | 0x170            | GPIOH interrupt                    |
| 93                                  | /                | 0x174            | /                                  |
| 94                                  | /                | 0x178            | /                                  |
| 95                                  | NSI              | 0x17C            | NSI interrupt                      |
| 96                                  | PSI              | 0x180            | PSI interrupt                      |
| 97                                  | BUS_TIMEOUT      | 0x184            | Bus timeout interrupt              |
| 98                                  | IOMMU            | 0x188            | IOMMU interrupt                    |
| 99                                  | DMA_S            | 0x18C            | DMA interrupt in secure domain     |
| <b>Display&amp;Image Interfaces</b> |                  |                  |                                    |
| 100                                 | DSI0             | 0x190            | DSI0 interrupt                     |
| 101                                 | TCON_LCD0        | 0x194            | TCON_LCD0 interrupt                |
| 102                                 | /                | 0x198            | /                                  |
| 103                                 | CSI_DMA0         | 0x19C            | CSI_DMA0 interrupt                 |
| 104                                 | CSI_DMA1         | 0x1A0            | CSI_DMA1 interrupt                 |
| 105                                 | CSI_DMA2         | 0x1A4            | CSI_DMA2 interrupt                 |
| 106                                 | CSI_DMA3         | 0x1A8            | CSI_DMA3 interrupt                 |
| 107                                 | CSI_PARSER0      | 0x1AC            | CSI_PARSER0 interrupt              |
| 108                                 | CSI_PARSER1      | 0x1B0            | CSI_PARSER1 interrupt              |
| 109                                 | CSI_ISPO         | 0x1B4            | CSI_ISPO interrupt                 |
| 110                                 | CSI_ISP1         | 0x1B8            | CSI_ISP1 interrupt                 |
| 111                                 | CSI_TDM          | 0x1BC            | CSI_TDM interrupt                  |
| 112                                 | CSI_CMB          | 0x1C0            | CSI_CMB interrupt                  |
| 113                                 | CSI_TOP          | 0x1C4            | CSI_TOP interrupt                  |
| 114                                 | /                | 0x1C8            | /                                  |
| 115                                 | /                | 0x1CC            | /                                  |

| <b>Interrupt Number</b> | <b>Interrupt Source</b> | <b>Interrupt Vector</b> | <b>Description</b>                |
|-------------------------|-------------------------|-------------------------|-----------------------------------|
| 116                     | /                       | 0x1D0                   | /                                 |
| 117                     | /                       | 0x1D4                   | /                                 |
| 118                     | /                       | 0x1D8                   | /                                 |
| 119                     | /                       | 0x1DC                   | /                                 |
| <b>Accelerator</b>      |                         |                         |                                   |
| 120                     | DE0                     | 0x1E0                   | DE0 interrupt                     |
| 121                     | /                       | 0x1E4                   | /                                 |
| 122                     | /                       | 0x1E8                   | /                                 |
| 123                     | G2D                     | 0x1EC                   | G2D interrupt                     |
| 124                     | CE_NS                   | 0x1F0                   | CE interrupt in non-secure domain |
| 125                     | CE                      | 0x1F4                   | CE interrupt in secure domain     |
| 126                     | VE                      | 0x1F8                   | VE interrupt                      |
| 127                     | /                       | 0x1FC                   | /                                 |
| 128                     | /                       | 0x200                   | /                                 |
| 129                     | GPU                     | 0x204                   | GPU interrupt                     |
| 130                     | /                       | 0x208                   | /                                 |
| 131                     | /                       | 0x20C                   | /                                 |
| 132                     | /                       | 0x210                   | /                                 |
| 133                     | /                       | 0x214                   | /                                 |
| 134                     | /                       | 0x218                   | /                                 |
| <b>CPUS domain</b>      |                         |                         |                                   |
| 135                     | NMI                     | 0x21C                   | NMI interrupt                     |
| 136                     | R_TIMER0                | 0x220                   | Timer0 interrupt in CPUS          |
| 137                     | R_TIMER1                | 0x224                   | Timer1 interrupt in CPUS          |
| 138                     | R_TIMER2                | 0x228                   | Timer2 interrupt in CPUS          |
| 139                     | R_TIMER3                | 0x22C                   | Timer3 interrupt in CPUS          |
| 140                     | R_Alarm                 | 0x230                   | Alarm interrupt in CPUS           |
| 141                     | R_WDOG                  | 0x234                   | Watchdog interrupt in CPUS        |
| 142                     | R_TWD                   | 0x238                   | Trust watchdog interrupt in CPUS  |
| 143                     | R_GPIOL                 | 0x23C                   | GPIOL interrupt in CPUS           |
| 144                     | R_UART                  | 0x240                   | UART interrupt in CPUS            |
| 145                     | R_TWIO                  | 0x244                   | TWIO interrupt in CPUS            |
| 146                     | R_TWI1                  | 0x248                   | TWI1 interrupt in CPUS            |
| 147                     | R_IR                    | 0x24C                   | IR interrupt in CPUS              |
| 148                     | R_PWM                   | 0x250                   | PWM interrupt in CPUS             |
| 149                     | /                       | 0x254                   | /                                 |
| 150                     | /                       | 0x258                   | /                                 |
| 151                     | R_PPU                   | 0x25C                   | PPU interrupt in CPUS             |
| <b>CPUX related</b>     |                         |                         |                                   |
| 160                     | C0_CTI0                 | 0x280                   | C0_CTI0 interrupt                 |
| 161                     | C0_CTI1                 | 0x284                   | C0_CTI1 interrupt                 |
| 162                     | C0_CTI2                 | 0x288                   | C0_CTI2 interrupt                 |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description            |
|------------------|------------------|------------------|------------------------|
| 163              | C0_CTI3          | 0x28C            | C0_CTI3 interrupt      |
| 164              | C0_COMMTX0       | 0x290            | C0_COMMTX0 interrupt   |
| 165              | C0_COMMTX1       | 0x294            | C0_COMMTX1 interrupt   |
| 166              | C0_COMMTX2       | 0x298            | C0_COMMTX2 interrupt   |
| 167              | C0_COMMTX3       | 0x29C            | C0_COMMTX3 interrupt   |
| 168              | C0_COMMRX0       | 0x2A0            | C0_COMMRX0 interrupt   |
| 169              | C0_COMMRX1       | 0x2A4            | C0_COMMRX1 interrupt   |
| 170              | C0_COMMRX2       | 0x2A8            | C0_COMMRX2 interrupt   |
| 171              | C0_COMMRX3       | 0x2AC            | C0_COMMRX3 interrupt   |
| 172              | C0_PMU0          | 0x2B0            | C0_PMU0 interrupt      |
| 173              | C0_PMU1          | 0x2B4            | C0_PMU1 interrupt      |
| 174              | C0_PMU2          | 0x2B8            | C0_PMU2 interrupt      |
| 175              | C0_PMU3          | 0x2BC            | C0_PMU3 interrupt      |
| 176              | C0_AXI_ERROR     | 0x2C0            | C0_AXI_ERROR interrupt |
| 177              | AXI_WR_IRQ       | 0x2C4            |                        |
| 178              | AXI_RD_IRQ       | 0x2C8            |                        |
| 179              | DBG_RSTREQ0      | 0x2CC            |                        |
| 180              | DBG_RSTREQ1      | 0x2D0            |                        |
| 181              | DBG_RSTREQ2      | 0x2D4            |                        |
| 182              | DBG_RSTREQ3      | 0x2D8            |                        |
| 183              | nVCPUMNTIRQ0     | 0x2DC            |                        |
| 184              | nVCPUMNTIRQ1     | 0x2E0            |                        |
| 185              | nVCPUMNTIRQ2     | 0x2E4            |                        |
| 186              | nVCPUMNTIRQ3     | 0x2E8            |                        |
| 187              | nCOMMIRQ0        | 0x2EC            |                        |
| 188              | nCOMMIRQ1        | 0x2F0            |                        |
| 189              | nCOMMIRQ2        | 0x2F4            |                        |
| 190              | nCOMMIRQ3        | 0x2F8            |                        |
| 191              | DBG_PWRUPREQ_out | 0x2FC            |                        |

For complete GIC information, refer to the **GIC PL400 technical reference manual** and **ARM GIC Architecture Specification V2.0**.

## 3.9. DMA

### 3.9.1. Overview

The direction memory access (DMA) is used to transfer data between a peripheral and a memory, between peripherals, or between memories. DMA is a high-speed data transfer operation that reduces the CPU resources.

The DMA has the following features:

- 8 channels DMA
- Provides 32 peripheral DMA requests for data read and 32 peripheral DMA requests for data write
- Transfer with linked list
- Programmable 8-,16-,32-,64-bit data width
- Programmable DMA burst length
- DRQ response includes wait mode and handshake mode
- Memory devices support non-aligned transform
- DMA channel supports pause function

### 3.9.2. Block Diagram

The following figure shows a block diagram of DMA.



Figure 3- 14. DMA Block Diagram

- **DMA\_ARBITER**: Arbitrate DMA read/write requirement of each channel, and convert to read/write requirement of each port.
- **DMA\_CHANNEL**: DMA transform engine. Each channel is independent. The priorities of DMA channels uses

polling mechanism. When the DMA requests from two peripherals are valid simultaneously, if DMA\_ARBITER is non-idle, the next channel of the current channel has the higher priority; if DMA\_ARBITER is idle, the smaller the number of the channel is, the higher the priority is, such as the channel0 has the highest priority, whereas the channel 7 has the lowest priority.

- **DMA\_MPORT:** Receive read/write requirement of DMA\_ARBITER, and convert to the corresponding MBUS access. It is mainly used to access DRAM.
- **DMA\_HPORT:** AHB master access interface, it is mainly used to access SRAM and IO device.
- **DMA\_FIFOCTL:** Internal FIFO cell control module.
- **DMA\_REGIF:** Common register module, mainly used to resolve AHB1 demand.
- **DMA\_CLKGATE:** Hardware auto clock gating control module.

DMA integrates 8 independent DMA channels. When DMA channel starts, DMA gets DMA descriptor by DMA\_DESC\_ADDR\_REG to use for the configuration information of the current DMA package transfer, and DMA can transfer data between the specified peripherals through the configuration information. When a package transfer finished, DMA judges whether the current channel transfer finished or continues to obtain/transfer the descriptor of the next package through the linked information in descriptor. When the chained address information of the descriptor indicates the current channel transfer is completed, DMA will close chain-transfer and the channel.

### 3.9.3. Operations and Functional Descriptions

#### 3.9.3.1. Clock and Reset

DMA is on AHB1. The clock of AHB1 influences the transfer efficiency of DMA.

#### 3.9.3.2. Typical Application



Figure 3- 15. DMA Typical Application Diagram

### 3.9.3.3. DRQ Type

**Table 3- 8. DMA DRQ Table**

| Source DRQ Type |             | Destination DRQ Type |             |
|-----------------|-------------|----------------------|-------------|
| port0           | SRAM        | port0                | SRAM        |
| port1           | DRAM        | port1                | DRAM        |
| port2           |             | 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           |             | port9                |             |
| port10          | NAND0       | port10               | NAND0       |
| port11          |             | port11               |             |
| port12          | GPADC       | port12               |             |
| port13          |             | port13               |             |
| 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          |             | port19               |             |
| port20          |             | port20               |             |
| port21          |             | port21               |             |
| 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          | OTG_EP1     | Port30               | OTG_EP1     |
| Port31          | OTG_EP2     | Port31               | OTG_EP2     |
| Port32          | OTG_EP3     | Port32               | OTG_EP3     |
| Port33          | OTG_EP4     | Port33               | OTG_EP4     |
| Port34          | OTG_EP5     | Port34               | OTG_EP5     |
| Port35          |             | Port35               |             |
| Port36          |             | Port36               |             |

|        |           |        |           |
|--------|-----------|--------|-----------|
| Port37 |           | Port37 |           |
| Port38 |           | Port38 |           |
| Port39 |           | Port39 |           |
| Port40 | R_UART-RX | Port40 | R_UART-TX |
| Port41 |           | Port41 |           |
| Port42 |           | Port42 | LEDC      |
| Port43 | TWI0      | Port43 | TWI0      |
| Port44 | TWI1      | Port44 | TWI1      |
| Port45 | TWI2      | Port45 | TWI2      |
| Port46 | TWI3      | Port46 | TWI3      |
| Port47 |           | Port47 |           |
| Port48 |           | Port48 |           |
| Port49 |           | Port49 |           |
| Port50 | R_TWI0    | Port50 | R_TWI0    |
| Port51 | R_TWI1    | Port51 | R_TWI1    |

### 3.9.3.4. DMA Descriptor



Figure 3- 16. DMA Descriptor

DMA descriptor is the configuration information of DMA transfer that decides the DMA working mode. Each descriptor includes 6 words, in turn, configuration, source address, destination address, byte counter, parameter, link.

(1) **Configuration** : Configure the following information by DMA\_CFG\_REG.

- **DRQ type of source and destination:** The DRQ signal of devices is as driving signal of DMA transfer.
- **Transferred address count mode:** IO mode indicates the address is fixed during transfer; linear mode indicates the address is increasing during transfer.
- **Transferred block length:** Block length is the amount of DMA transferred data in one-shot valid DRQ. The block length supports 1-bit,4-bit,8-bit or 16-bit mode.
- **Transferred data width:** Data width indicates the data width of every operation, and supports 8-bit,16-bit,32-bit or 64-bit mode.

(2) **Source Address:** Configure the transferred source address.

(3) **Destination Address:** Configure the transferred destination address.

DMA reads data from the source address, then writes data to the destination address.

In descriptor, the **Source/Destination Address** stores the lower 32-bit of the 34-bit byte address, and the higher

2-bit is stored in **Parameter**. The specific position is as follows.

**Table 3- 9. Source/Destination Address Distribution**

| Descriptor Group    | Bit   | Description                                                                |
|---------------------|-------|----------------------------------------------------------------------------|
| Source Address      | 31:0  | DMA transfers the lower 32-bit of 34-bit byte source address               |
| Destination Address | 31:0  | DMA transfers the lower 32-bit of 34-bit byte destination address          |
| Paramter            | 31:20 | Reserved                                                                   |
|                     | 19:18 | DMA transfers the high 2-bit of 34-bit byte destination address            |
|                     | 17:16 | DMA transfers the high 2-bit of 34-bit byte source address                 |
|                     | 15:8  | Reserved                                                                   |
|                     | 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-bit of word address |
|                     | 1:0   | The address of the next group descriptor, the higher 2-bit of word address |

From the above table, real DMA source address(byte mode) = { Paramter [17:16], Source Address [31:0]};

Real DMA desnitiation address(byte mode) = { Paramter [19:18], Destination Address [31:0]};

And real link address (byte mode) = {Link[1:0], Link[31:2], 2'b00}.

- (4) **Byte counter:** Configure the amount of a package. The maximum package is not more than ( $2^{25}-1$ ) bytes. If the amount of the package reaches the maximum value, even if DRQ is valid, DMA should stop the current transfer.
- (5) **Parameter:** Configure the interval between data block. The parameter is valid for non-memory peripherals. When DMA detects that DRQ is high level, DMA transfers block cycle. And during time, the changing of DRQ is ignored. After transferred, DMA waits the setting cycle( WAIT\_CYC), then executes the next DRQ detection.
- (6) **Link:** If the value of the link is 0xFFFFF800, the current package is at the end of the linked list. DMA will stop transfer after the package is transferred; if the value of the link is not 0xFFFFF800, the value of the link is considered the descriptor address of the next package.



Figure 3- 17. DMA Chain Transfer

### 3.9.3.5. Interrupt

The half package interrupt is enabled, DMA sends half package interrupt after the half package transfer completes. The total package interrupt is enabled, DMA sends package end interrupt after the total package transfer completes. The total queue interrupt is enabled, DMA sends queue end interrupt after the total queue completes. Notice that when CPU does not respond to the interrupts timely, or two DMA interrupts generate very closely, the later interrupt may override the former one. So for CPU, the DMA has only a system interrupt source.

### 3.9.3.6. Security

DMA supports system Trustzone, and supports the secure mode configuration of DMA channel. Each DMA channel is secure by default. When system Trustzone is enabled, DMA is secure, only the secure devices can access DMA, any non-secure access is invalid.

When DMA channel is configured to non-secure, then the channel can only access the non-secure memory area. DMA cannot write data to secure memory area, the read-back data from secure memory area is 0.

### 3.9.3.7. Clock Gating

DMA\_CLK\_GATE module is the auto clock gating control module by hardware. DMA\_CLK\_GATE module is mainly used to generate the clock of DMA sub-module and the local circuit in module, including clock gating of channel and clock gating of public part.

The clock gating of the channel indicates DMA clock can auto-enable when the system accesses the current DMA channel register and DMA channel is enabled. When DMA transfer is completed, DMA channel clock can auto-disable after 16 HCLK delay, meanwhile the clock of DMA channel, the corresponding channel control and FIFO control will be

closed.

The clock gating of the common part indicates the clock of the common circuit can auto-disable when all DMA channels are opened. The common circuit includes the common circuit of FIFO control module, MPORT module and memory bus clock.

DMA clock gating can support all the functions stated above or not by software.

### 3.9.3.8. Transfer Mode

DMA supports two data transfer modes: wait mode and handshake mode.

#### (1) Wait Mode

When device request signal enters DMA, the device request signal is transformed into the internal DRQ signal through block and wait counter. The transformed principle is as follows.

- When DMA detects the external request signal valid, DMA starts to operate the device, the internal DRQ always holds high level before the block operating amount reaches.
- When the transfer amount of DMA reaches the block operating amount, the internal DRQ pulls low automatically.
- After the internal DRQ holds low automatically at the DMA cycle of wait counter times, DMA restarts to detect the external request, if the external request signal is valid, then the next transfer starts.

#### (2) Handshake Mode

- When DMA detects the external request signal valid, DMA starts to operate the device, the internal DRQ always holds high level before the block operating amount reaches.
- When the transfer amount of DMA reaches the block operating amount, the internal DRQ pulls low automatically; meanwhile within the last DMA operation before reaching block amount, DMA follows the operating demand to send DMA last signal simultaneously.
- The DMA last signal that is used as a part of DMA demand transmits at BUS, when the device receives the operating demand of DMA last at BUS, the device can judge DMA transfer block length finished, that is before transmit the request again, DMA operation cannot appear, and a DMA active signal is generated to the DMA controller. Notice that each DRQ signal of device corresponds to an active signal, if the device has many DRQ signals, then DMA returns different active signal through different bus operation.
- When DMA receives the transmitted active signal of devices, DMA ACK signal is returned to devices.
- After the device receives DMA ACK signal, if all operations of devices are completed, FIFO status and DRQ status are refreshed, then active signal is set as invalid.
- When DMA detects the falling edge of active signal, then the corresponding ACK signal is set as invalid, and DMA restarts to detect the external request signal. If the request signal is valid, then the next transfer starts.



Figure 3- 18. DMA Transfer Mode

### 3.9.3.9. Auto-alignment Function

The DMA supports address auto alignment of non-IO devices, that is when the start address of non-IO devices is non 32-byte aligned, DMA firstly aligns the burst transfer within 32-byte to 32-byte. If the device of a DMA channel is configured to non-IO type, and the start address is 0x86, then DMA firstly aligns 26-byte burst transfer to 0xA0, then DMA transfers by 64-byte burst(maximum transfer amount of MBUS allowed). The address 32-byte alignment helps to improve the DRAM access efficiency.

IO devices do not support address alignment, so the bit width of IO devices must match the address offset, or not DMA ignores the non-consistency and indirectly transmits data of the corresponding bit width to the address.

The DMA descriptor address does not support auto-aligned function. The address must ensure word-aligned, or not DMA cannot identify descriptor.

### 3.9.3.10. Operating Mode

#### 3.9.3.10.1. DMA Clock Control

- The DMA clock is synchronous with AHB1 clock. Make sure that open the DMA gating bit of AHB1 clock before access DMA register.
- The reset input signal of DMA is asynchronous with AHB1, and is low valid by default. Make sure that de-assert the reset signal of DMA before access DMA register.
- To avoid indefinite state within registers , firstly de-assert the reset signal, secondly open the gating bit of AHB1.
- DMA has the function of clock auto gating, DMA clock can be disabled in DMA idle state using software to reduce power consumption. DMA enables clock auto gating by default.

#### 3.9.3.10.2. DMA Transfer Process

The DMA transfer process is as follows.

- (1) Request DMA channel, and judge the idle state of the channel by whether DMA channel is enabled.
- (2) Write the descriptor(6 words) into memory, the descriptor must be word-aligned. Refer to **3.9.3.4 DMA descriptor** in detail.
- (3) Write the start address of storing descriptor to **DMA\_DESC\_ADDR\_REG**.
- (4) Enable DMA channel, and write the corresponding channel to **DMA\_EN\_REG**.
- (5) DMA obtains the descriptor information.
- (6) Start to transmit a package, when half package is completed, DMA sends **Half Package Transfer Interrupt**; when total package is completed, DMA sends **Package End Transfer Interrupt**. These interrupt status can be read by **DMA\_IRQ\_PEND\_REG**.
- (7) Set **DMA\_PAU\_REG** to pause or resume the data transfer.
- (8) After completed the total package transfer, 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; if the link is other value, the next package starts to transmit. When the transfer ends, DMA sends **Queue End Transfer Interrupt**.
- (9) Disable the DMA channel.



Figure 3- 19. DMA Transfer Process

### 3.9.3.10.3. DMA Interrupt

- (1) Enable interrupt: write the corresponding interrupt enable of **DMA\_IRQ\_EN\_REG**, when the corresponding interrupt condition is satisfied, the corresponding interrupt generates.
- (2) After enter the interrupt process, write **DMA\_IRQ\_PEND\_REG** to clear the interrupt pending, and execute the process of waiting for the interrupt.
- (3) Resume the interrupt and continue to execute the interrupted process.

### 3.9.4. Programming Guidelines

- (1) The transfer width of IO type device is consistent with the offset of start address.
- (2) MBUS protocol does not support read operation of non-integer word, so for non-integer word read operation, device must ignore redundant inconsistent data between data width and configuration, that is, the device of non-integer word must interpret DMA demand through its FIFO width instead of read demand width.
- (3) When the DMA transfer is paused, this is equivalent to invalid DRQ. Because DMA transfer command has a certain time delay, DMA will not stop transfer immediately until the current command and the command in Arbiter finished, at most 32-byte data.

DMA application example :

```
writel(0x00000000, mem_address + 0x00); //Setting configuration, mem_address must be word-aligned  
writel(0x00001000, mem_address + 0x04); // Setting the start address for the source device  
writel(0x20000000, mem_address + 0x08); //Setting the start address for the destination device  
writel(0x00000020, mem_address + 0x0C); // Setting data package size  
writel(0x00000000, mem_address + 0x10); //Setting parameter  
writel(0xFFFFF800, mem_address + 0x14); //Setting the start address for the next descriptor  
writel(mem_address, 0x01C02000+ 0x100 + 0x08); //Setting the start address for the DMA channel0 descriptor  
do{  
    If(mem_address == readl(0x01C02000 + 0x100 + 0x08));  
    break;  
}while(1); //Make sure writing operation valid  
writel(0x00000001, 0x01C02000 + 0x100 + 0x00); // Enable DMA channel0 transfer
```

DMA supports increasing data package in transfer, there are a few points to note here.

- When the value of **DMA Channel Descriptor Address Register** is 0xFFFFF800, it indicates that DMA channel has got back the descriptor of the last package. When DMA channel completed the package data transfer, DMA channel will stop automatically data transfer.
- If data packages are needed to increase, then at first it is essential to judge that whether DMA channel has got back the descriptor of the last package, if DMA channel has got back the descriptor of the last package, then this is impossible for increasing data package, DMA channel need start again. If DMA is not transmitting the last package, then the last descriptor address 0xFFFFF800 can be changed to the start address of the next descriptor.
- To ensure that the data changed valid, we can read again the value of **DMA Channel Descriptor Address Register** after changed the data. If there is not 0xFFFFF800, then it indicates that increasing data package is succeed, and fail otherwise. Because the process of increasing data package needs some time, during this time, DMA channel may get back the descriptor of the last package. At the moment we can read again **DMA Channel Current Source Address Register** and **DMA Channel Current Destination Address Register**, if the increasing memory address accords with the information of the increasing data package, then the increasing data package is succeed, and fail otherwise.
- To ensure the higher success rate, it is suggested that increase data package before half package interrupt of penultimate data package.

### 3.9.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| DMA         | 0x03002000   |

| Register Name      | Offset                 | Description                                     |
|--------------------|------------------------|-------------------------------------------------|
| DMA_IRQ_EN_REG0    | 0x0000                 | DMA IRQ Enable Register 0                       |
| DMA_IRQ_PEND_REG0  | 0x0010                 | DMA IRQ Pending Register 0                      |
| DMA_SEC_REG        | 0x0020                 | DMA Security Register                           |
| DMA_AUTO_GATE_REG  | 0x0028                 | DMA Auto Gating Register                        |
| DMA_STA_REG        | 0x0030                 | DMA Status Register                             |
| DMA_EN_REG         | 0x0100+N*0x0040        | DMA Channel Enable Register (N=0~7)             |
| DMA_PAU_REG        | 0x0100+N*0x0040+0x0004 | DMA Channel Pause Register(N=0~7)               |
| DMA_DESC_ADDR_REG  | 0x0100+N*0x0040+0x0008 | DMA Channel Start Address Register(N=0~7)       |
| DMA_CFG_REG        | 0x0100+N*0x0040+0x000C | DMA Channel Configuration Register(N=0~7)       |
| DMA_CUR_SRC_REG    | 0x0100+N*0x0040+0x0010 | DMA Channel Current Source Register(N=0~7)      |
| DMA_CUR_DEST_REG   | 0x0100+N*0x0040+0x0014 | DMA Channel Current Destination Register(N=0~7) |
| DMA_BCNT_LEFT_REG  | 0x0100+N*0x0040+0x0018 | DMA Channel Byte Counter Left Register(N=0~7)   |
| DMA_PARA_REG       | 0x0100+N*0x0040+0x001C | DMA Channel Parameter Register(N=0~7)           |
| DMA_MODE_REG       | 0x0100+N*0x0040+0x0028 | DMA Mode Register(N=0~7)                        |
| DMA_FDESC_ADDR_REG | 0x0100+N*0x0040+0x002C | DMA Former Descriptor Address Register(N=0~7)   |
| DMA_PKG_NUM_REG    | 0x0100+N*0x0040+0x0030 | DMA Package Number Register(N=0~7)              |

### 3.9.6. Register Description

#### 3.9.6.1. 0x0000 DMA IRQ Enable Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: DMA_IRQ_EN_REG0                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31             | /          | /           | /                                                                                           |
| 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 | /   | /   | /                                                                                           |
| 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<br>DMA 6 Half Package Transfer Interrupt Enable<br>0: Disable<br>1: Enable |
| 23 | /   | /   | /                                                                                           |
| 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 | /   | /   | /                                                                                           |
| 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 | /   | /   | /                                                                                           |
| 14 | R/W | 0x0 | DMA3_QUEUE_IRQ_EN<br>DMA 3 Queue End Transfer Interrupt Enable<br>0: Disable<br>1: Enable   |
| 13 | R/W | 0x0 | DMA3_PKG_IRQ_EN                                                                             |

|    |     |     |                                                                                             |
|----|-----|-----|---------------------------------------------------------------------------------------------|
|    |     |     | 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 | /   | /   | /                                                                                           |
| 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  | /   | /   | /                                                                                           |
| 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<br>1: Enable |
| 3  | /   | /   | /                                                                                           |
| 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              |

|  |  |  |           |
|--|--|--|-----------|
|  |  |  | 1: Enable |
|--|--|--|-----------|

### 3.9.6.2. 0x0010 DMA IRQ Pending Status Register 0 (Default Value: 0x0000\_0000)

| Offset:0x0010 |            |             | Register Name: DMA_IRQ_PEND_REG0                                                                                                       |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                            |
| 31            | /          | /           | /                                                                                                                                      |
| 30            | R/W1C      | 0x0         | DMA7_QUEUE_IRQ_PEND<br>DMA 7 Queue End Transfer Interrupt Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 29            | R/W1C      | 0x0         | DMA7_PKG_IRQ_PEND<br>DMA 7 Package End Transfer Interrupt Pending. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 27            | /          | /           | /                                                                                                                                      |
| 26            | R/W1C      | 0x0         | DMA6_QUEUE_IRQ_PEND<br>DMA 6 Queue End Transfer Interrupt Pending. Setting 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. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 23            | /          | /           | /                                                                                                                                      |
| 22            | R/W1C      | 0x0         | DMA5_QUEUE_IRQ_PEND<br>DMA 5 Queue End Transfer Interrupt Pending. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending   |
| 20 | R/W1C | 0x0 | DMA5_HLAF_IRQ_PEND<br>DMA 5 Half Package Transfer Interrupt Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 19 | /     | /   | /                                                                                                                                      |
| 18 | R/W1C | 0x0 | DMA4_QUEUE_IRQ_PEND<br>DMA 4 Queue End Transfer Interrupt Pending. Setting 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. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 15 | /     | /   | /                                                                                                                                      |
| 14 | R/W1C | 0x0 | DMA3_QUEUE_IRQ_PEND<br>DMA 3 Queue End Transfer Interrupt Pending. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending.  |
| 13 | R/W1C | 0x0 | DMA3_PKG_IRQ_PEND<br>DMA 3 Package End Transfer Interrupt Pending. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 11 | /     | /   | /                                                                                                                                      |
| 10 | R/W1C | 0x0 | DMA2_QUEUE_IRQ_PEND<br>DMA 2 Queue End Transfer Interrupt Pending. Setting 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. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 7 | /     | /   | /                                                                                                                                      |
| 6 | R/W1C | 0x0 | DMA1_QUEUE_IRQ_PEND<br>DMA 1 Queue End Transfer Interrupt Pending. Setting 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. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |
| 3 | /     | /   | /                                                                                                                                      |
| 2 | R/W1C | 0x0 | DMA0_QUEUE_IRQ_PEND<br>DMA 0 Queue End Transfer Interrupt Pending. Setting 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. Setting 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. Setting 1 to the bit will clear it.<br>0: No effect<br>1: Pending |

### 3.9.6.3. 0x0020 DMA Security Register (Default Value: 0x0000\_00FF)

| Offset:0x0020 |            |             | Register Name: DMA_SEC_REG                                       |
|---------------|------------|-------------|------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                      |
| 31:8          | /          | /           | /                                                                |
| 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<br>1: Non-secure |
| 0             | R/W        | 0x1         | DMA0_SEC<br>DMA channel 0 security<br>0: Secure<br>1: Non-secure |

### 3.9.6.4. 0x0028 DMA Auto Gating Register (Default Value: 0x0000\_0000)

| Offset:0x0028 |            |             | Register Name: DMA_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, the bit-2 should be set up.

### 3.9.6.5. 0x0030 DMA Status Register (Default Value: 0x0000\_0000)

| Offset:0x0030 |            |             | Register Name: DMA_STA_REG                                |
|---------------|------------|-------------|-----------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                               |
| 31            | R          | 0x0         | MBUS FIFO Status<br>0: Empty<br>1: Not Empty              |
| 30:8          | /          | /           | /                                                         |
| 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<br>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            |

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

### 3.9.6.6. 0x0100+N\*0x0040 DMA Channel Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040 (N=0~7) |            |             | Register Name: DMA_EN_REG                               |
|--------------------------------|------------|-------------|---------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                             |
| 31:1                           | /          | /           | /                                                       |
| 0                              | R/W        | 0x0         | DMA_EN<br>DMA Channel Enable<br>0: Disable<br>1: Enable |

### 3.9.6.7. 0x0104+N\*0x0040 DMA Channel Pause Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0004(N=0~7) |            |             | Register Name: DMA_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 |

### 3.9.6.8. 0x0108+N\*0x0040 DMA Channel Descriptor Address Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0008(N=0~7) |            |             | Register Name: DMA_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 30 bits.<br>The Descriptor Address must be word-aligned. |

|     |     |     |                                                                                                                                                                         |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | R/W | 0x0 | DMA_DESC_HIGH_ADDR<br>DMA Channel Descriptor High Address, High 2 bits<br>The real address is as below:<br>DMA Channel Descriptor Address = {bit[1:0],bit[31:2],2'b00}; |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 3.9.6.9. 0x010C+N\*0x0040 DMA Channel Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x000C(N=0~7) |            |             | Register Name: DMA_CFG_REG                                                                                |
|--------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                                                                                               |
| 31: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: 64-bit  |
| 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: 64-bit        |
| 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                                                      |

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

### 3.9.6.10. 0x0110+N\*0x0040 DMA Channel Current Source Address Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0010(N=0~7) |            |             | Register Name: DMA_CUR_SRC_REG                                |
|--------------------------------------|------------|-------------|---------------------------------------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                                                   |
| 31:0                                 | R          | 0x0         | DMA_CUR_SRC<br>DMA Channel Current Source Address, read only. |

### 3.9.6.11. 0x0114+N\*0x0040 DMA Channel Current Destination Address Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0014(N=0~7) |            |             | Register Name: DMA_CUR_DEST_REG                                     |
|--------------------------------------|------------|-------------|---------------------------------------------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                                                         |
| 31:0                                 | R          | 0x0         | DMA_CUR_DEST<br>DMA Channel Current Destination Address, read only. |

### 3.9.6.12. 0x0118+N\*0x0040 DMA Channel Byte Counter Left Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0018(N=0~7) |            |             | Register Name: DMA_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. |

### 3.9.6.13. 0x011C+N\*0x0040 DMA Channel Parameter Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x001C(N=0~7) |            |             | Register Name: DMA PARA_REG   |
|--------------------------------------|------------|-------------|-------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                   |
| 31:8                                 | /          | /           | /                             |
| 7:0                                  | R          | 0x0         | WAIT_CYC<br>Wait Clock Cycles |

### 3.9.6.14. 0x0128+N\*0x0040 DMA Mode Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0028(N=0~7) |            |             | Register Name: DMA_MODE_REG                       |
|--------------------------------------|------------|-------------|---------------------------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                                       |
| 31:4                                 | /          | /           | /                                                 |
| 3                                    | R/W        | 0x0         | DMA_DST_MODE<br>0: Wait mode<br>1: Handshake mode |
| 2                                    | R/W        | 0x0         | DMA_SRC_MODE<br>0: Wait mode<br>1: Handshake mode |
| 1:0                                  | /          | /           | /                                                 |

### 3.9.6.15. 0x012C+N\*0x0040 DMA Former Descriptor Address Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x002C(N=0~7) |            |             | Register Name: DMA_FDESC_ADDR_REG                                                                             |
|--------------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit                                  | Read/Write | Default/Hex | Description                                                                                                   |
| 31:0                                 | R          | 0x0         | DMA_FDESC_ADDR<br>This register is used to store the former value of DMA Channel Descriptor Address Register. |

### 3.9.6.16. 0x0130+N\*0x0040 DMA Package Number Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0040+0x0030(N=0~7) |            |             | Register Name: DMA_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. |

## 3.10. Thermal Sensor Controller

### 3.10.1. Overview

Thermal sensors have became common elements in wide range of modern system on chip (SoC) platform. Thermal sensors are used to constantly monitor the temperature on the chip.

The Thermal Sensor Controller(THS) embeds three thermal sensors, sensor0 is located in CPU, sensor1 is located in GPU, and sensor2 is located in DDR. The thermal sensor can generate interrupt to SW to lower temperature via DVFS, on reaching a certain thermal threshold.

The THS has the following features:

- Temperature Accuracy :  $\pm 3^{\circ}\text{C}$  from  $0^{\circ}\text{C}$  to  $+100^{\circ}\text{C}$ ,  $\pm 5^{\circ}\text{C}$  from  $-25^{\circ}\text{C}$  to  $+125^{\circ}\text{C}$
- Power supply voltage: 1.8 V
- Averaging filter for thermal sensor reading
- Supports over-temperature protection interrupt and over-temperature alarm interrupt

### 3.10.2. Block Diagram

Figure 3-20 shows a block diagram of the Thermal Sensor Controller.



Figure 3- 20. Thermal Sensor Controller Block Diagram

### 3.10.3. Operations and Functional Descriptions

#### 3.10.3.1. Clock Sources

The THS gets one clock source. Table 3-9 describes the clock source for Thermal Sensor Controller. Users can see **Clock Controller Unit(CCU)** for clock setting, configuration and gating information.

**Table 3- 9. Thermal Sensor Controller Clock Sources**

| Clock Sources | Description |
|---------------|-------------|
| OSC24M        | 24MHz clock |

### 3.10.3.2. Timing Requirements

CLK\_IN = 24 MHz

CONV\_TIME(Conversion Time) =  $1/(24 \text{ MHz}/14 \text{ Cycles}) = 0.583 \text{ (us)}$

TACQ >  $1/(24 \text{ MHz}/24 \text{ Cycles})$

THERMAL\_PER > ADC Sample Frequency > TACQ+CONV\_TIME

**Figure 3- 21. Thermal Sensor Time Requirement**

### 3.10.3.3. Interrupt

The THS has four interrupt sources, such as DATA\_IRQ, SHUTDOWN\_IRQ, ALARM\_IRQ and ALARM\_OFF\_IRQ. Figure 3-22 shows the thermal sensor interrupt sources.

**Figure 3- 22. Thermal Sensor Controller Interrupt Source**

When temperature is higher than Alarm\_Threshold (Alarm Threshold for hot temperature), ALARM\_IRQ is generated. When temperature is lower than Alarm\_Off\_Thersholt (Alarm threshold for hysteresis temperature), ALARM\_OFF\_IRQ is generated. And ALARM\_OFF\_IRQ is fall edge trigger.

### 3.10.3.4. THS Temperature Conversion Formula

$T = (\text{sensor\_data} - 2794) / (-14.882)$ , the unit of T is Celsius.

sensor\_data: read from sensor data register.

### 3.10.4. Programming Guidelines

The initial process of the THS is as follows.



Figure 3- 23. THS Initial Process

The formula of THS is  $y = -ax + b$ . In FT stage, THS is calibrated through ambient temperature, the calibration value is written in EFUSE. Please refer to SID Spec about EFUSE information.

Before enabling THS, read EFUSE value and write the value to **THS01\_CDATA**, **THS2\_CDATA**.

#### (1).Query Mode

Step1: Write 0x1 to the bit16 of **THS\_BGR\_REG** to dessert reset.

Step2: Write 0x1 to the bit0 of **THS\_BGR\_REG** to open THS clock.

Step3: Write 0x2F to the bit[15:0] of **THS\_CTRL** to set ADC acquire time.

Step4: Write 0x1DF to the bit[31:16] of **THS\_CTRL** to set ADC sample frequency divider.

Step5: Write 0x3A to the bit[31:12] of **THS\_PER** to set THS work period.

Step6: Write 0x1 to the bit2 of **THS\_FILTER** to enable temperature convert filter.

Step7: Write 0x1 to the bit[1:0] of **THS\_FILTER** to select filter type.

Step8: Read THS efuse value from SID, then write the efuse value to **THS\_CDATA** to calibrate THS.

Step9: Write 0x1 to the bit[0] Of **THS\_EN** to enable THS.

Step10: Read the bit[0] of **THS\_DATA\_INTS**, if is 1, temperature conversion is complete.

Step11: Read the bit[11:0] of **THS\_DATA**, calculate THS temperature based on THS Temperature Conversion Formula in Section 3.10.3.4.

## (2). Interrupt Mode

Step1: Write 0x1 to the bit16 of **THS\_BGR\_REG** to dessert reset.

Step2: Write 0x1 to the bit0 of **THS\_BGR\_REG** to open THS clock.

Step3: Write 0x2F to the bit[15:0] of **THS\_CTRL** to set ADC acquire time.

Step4: Write 0x1DF to the bit[31:16] of **THS\_CTRL** to set ADC sample frequency divider.

Step5: Write 0x3A to the bit[31:12] of **THS\_PER** to set THS work period.

Step6: Write 0x1 to the bit2 of **THS\_FILTER** to enable temperature convert filter.

Step7: Write 0x1 to the bit[1:0] of **THS\_FILTER** to select filter type.

Step8: Read THS efuse value from SID, then write the efuse value to **THS\_CDATA** to calibrate THS.

Step9: Write 0x1 to the bit[0] of **THS\_DATA\_INTC** to enable the interrupt of THS.

Step10: Set GIC interface based on IRQ 53, write the bit[21] of the 0x03021104 register to 0x1.

Step11: Put interrupt handler address into interrupt vector table.

Step12: Write 0x1 to the bit[0] of **THS\_EN** to enable THS.

Step13: Read the bit[0] of **THS\_DATA\_INTS**, if is 1, temperature conversion is complete.

Step14: Read the bit[11:0] of **THS\_DATA**, calculate THS temperature based on THS Temperature Conversion Formula in Section 3.10.3.4.

## 3.10.5. Register List

| Module Name    | Base Address |
|----------------|--------------|
| Thermal Sensor | 0x05070400   |

| Register Name       | Offset | Description                                     |
|---------------------|--------|-------------------------------------------------|
| THS_CTRL            | 0x0000 | THS Control Register                            |
| THS_EN              | 0x0004 | THS Enable Register                             |
| THS_PER             | 0x0008 | THS Period Control Register                     |
| THS_DATA_INTC       | 0x0010 | THS Data Interrupt Control Register             |
| THS_SHUT_INTC       | 0x0014 | THS Shut Interrupt Control Register             |
| THS_ALARM_INTC      | 0x0018 | THS Alarm Interrupt Control Register            |
| THS_DATA_INTS       | 0x0020 | THS Data Interrupt Status Register              |
| THS_SHUT_INTS       | 0x0024 | THS Shut Interrupt Status Register              |
| THS_ALARMO_INTS     | 0x0028 | THS Alarm off Interrupt Status Register         |
| THS_ALARM_INTS      | 0x002C | THS Alarm Interrupt Status Register             |
| THS_FILTER          | 0x0030 | THS Median Filter Control Register              |
| THS0_ALARM_CTRL     | 0x0040 | THS0 Alarm Threshold Control Register           |
| THS1_ALARM_CTRL     | 0x0044 | THS1 Alarm Threshold Control Register           |
| THS2_ALARM_CTRL     | 0x0048 | THS2 Alarm Threshold Control Register           |
| THS01_SHUTDOWN_CTRL | 0x0080 | THS0 & THS1 Shutdown Threshold Control Register |

|                    |        |                                          |
|--------------------|--------|------------------------------------------|
| THS2_SHUTDOWN_CTRL | 0x0084 | THS2 Shutdown Threshold Control Register |
| THS01_CDATA        | 0x00A0 | THS0 & THS1 Calibration Data             |
| THS2_CDATA         | 0x00A4 | THS2 Calibration Data                    |
| THS0_DATA          | 0x00C0 | THS0 Data Register                       |
| THS1_DATA          | 0x00C4 | THS1 Data Register                       |
| THS2_DATA          | 0x00C8 | THS2 Data Register                       |

### 3.10.6. Register Description

#### 3.10.6.1. 0x0000 THS Control Register(Default Value : 0x01DF\_002F)

| Offset: 0x0000 |            |             | Register Name: THS_CTRL                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Rear/Write | Default/Hex | Description                                                                                              |
| 31:16          | R/W        | 0x1DF       | FS_DIV<br>ADC Sample Frequency Divider<br>CLK_IN/(N+1) , N > 0x17<br>The default value indicates 50 kHz. |
| 15:0           | R/W        | 0x2F        | TACQ<br>ADC Acquire Time<br>CLK_IN/(n+1)<br>The default value indicates 2us.                             |

#### 3.10.6.2. 0x0004 THS Enable Register(Default Value : 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: THS_EN                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Rear/Write | Default/Hex | Description                                                                                          |
| 31:19          | /          | /           | /                                                                                                    |
| 18:17          | R/W        | 0x0         | Ctrl for psensor                                                                                     |
| 16             | R/W        | 0x0         | PSENSOR_EN<br>Enable temperature measurement psensor<br>0:Sensor is T sensor<br>1:Sensor is P sensor |
| 15:3           | /          | /           | /                                                                                                    |
| 2              | R/W        | 0x0         | THS2_EN<br>Enable temperature measurement sensor2<br>0:Disable<br>1:Enable                           |
| 1              | R/W        | 0x0         | THS1_EN<br>Enable temperature measurement sensor1<br>0:Disable<br>1:Enable                           |
| 0              | R/W        | 0x0         | THS0_EN                                                                                              |

|  |  |  |                                                                 |
|--|--|--|-----------------------------------------------------------------|
|  |  |  | Enable temperature measurement sensor0<br>0:Disable<br>1:Enable |
|--|--|--|-----------------------------------------------------------------|

### 3.10.6.3. 0x0008 THS Period Control Register(Default Value: 0x0003\_A000)

| Offset: 0x0008 |            |             | Register Name: THS_PER                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:12          | R/W        | 0x3A        | THERMAL_PER<br>4096*(n+1)/CLK_IN<br>The default value indicates 10 ms. |
| 11:0           | /          | /           | /                                                                      |

### 3.10.6.4. 0x0010 THS Data Interrupt Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: THS_DATA_INTC                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:3           | /          | /           | /                                                                                            |
| 2              | R/W        | 0x0         | THS2_DATA_IRQ_EN<br>Selects temperature measurement data of sensor2<br>0:Disable<br>1:Enable |
| 1              | R/W        | 0x0         | THS1_DATA_IRQ_EN<br>Selects temperature measurement data of sensor1<br>0:Disable<br>1:Enable |
| 0              | R/W        | 0x0         | THS0_DATA_IRQ_EN<br>Selects temperature measurement data of sensor0<br>0:Disable<br>1:Enable |

### 3.10.6.5. 0x0014 THS Shut Interrupt Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: THS_SHUT_INTC                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:3           | /          | /           | /                                                                               |
| 2              | R/W        | 0x0         | SHUT_INT2_EN<br>Selects shutdown interrupt for sensor2<br>0:Disable<br>1:Enable |
| 1              | R/W        | 0x0         | SHUT_INT1_EN                                                                    |

|   |     |     |                                                                                 |
|---|-----|-----|---------------------------------------------------------------------------------|
|   |     |     | Selects shutdown interrupt for sensor1<br>0:Disable<br>1:Enable                 |
| 0 | R/W | 0x0 | SHUT_INTO_EN<br>Selects shutdown interrupt for sensor0<br>0:Disable<br>1:Enable |

### 3.10.6.6. 0x0018 THS Alarm Interrupt Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: THS_ALARM_INTC                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:3           | /          | /           | /                                                                             |
| 2              | R/W        | 0x0         | ALARM_INT2_EN<br>Selects alarm interrupt for sensor2<br>0:Disable<br>1:Enable |
| 1              | R/W        | 0x0         | ALARM_INT1_EN<br>Selects alarm interrupt for sensor1<br>0:Disable<br>1:Enable |
| 0              | R/W        | 0x0         | ALARM_INTO_EN<br>Selects alarm interrupt for sensor0<br>0:Disable<br>1:Enable |

### 3.10.6.7. 0x0020 THS Data Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: THS_DATA_INTS                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:3           | /          | /           | /                                                                                            |
| 2              | R/W1C      | 0x0         | THS2_DATA_IRQ_STS<br>Data interrupt status for sensor2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | THS1_DATA_IRQ_STS<br>Data interrupt status for sensor1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | THS0_DATA_IRQ_STS<br>Data interrupt status for sensor0<br>Write '1' to clear this interrupt. |

### 3.10.6.8. 0x0024 THS Shut Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: THS_SHUT_INTS                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:3           | /          | /           | /                                                                                            |
| 2              | R/W1C      | 0x0         | SHUT_INT2_STS<br>Shutdown interrupt status for sensor2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | SHUT_INT1_STS<br>Shutdown interrupt status for sensor1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | SHUT_INTO_STS<br>Shutdown interrupt status for sensor0<br>Write '1' to clear this interrupt. |

### 3.10.6.9. 0x0028 THS Alarm Off Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: THS_ALARM_INTS                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:3           | /          | /           | /                                                                                               |
| 2              | R/W1C      | 0x0         | ALARM_OFF2_STS<br>Alarm interrupt off pending for sensor2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | ALARM_OFF1_STS<br>Alarm interrupt off pending for sensor1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | ALARM_OFF0_STS<br>Alarm interrupt off pending for sensor0<br>Write '1' to clear this interrupt. |

### 3.10.6.10. 0x002C THS Alarm Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: THS_ALARM_INTS                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:3           | /          | /           | /                                                                                           |
| 2              | R/W1C      | 0x0         | ALARM_INT2_STS<br>Alarm interrupt pending for sensor2<br>Write '1' to clear this interrupt. |
| 1              | R/W1C      | 0x0         | ALARM_INT1_STS<br>Alarm interrupt pending for sensor1<br>Write '1' to clear this interrupt. |
| 0              | R/W1C      | 0x0         | ALARM_INTO_STS                                                                              |

|  |  |  |                                                                           |
|--|--|--|---------------------------------------------------------------------------|
|  |  |  | Alarm interrupt pending for sensor0<br>Write '1' to clear this interrupt. |
|--|--|--|---------------------------------------------------------------------------|

### 3.10.6.11. 0x0030 Median Filter Control Register(Default Value: 0x0000\_0001)

| Offset: 0x0030 |            |             | Register Name: THS_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 |

### 3.10.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       | ALARM0_T_HOT<br>Thermal Sensor0 alarm threshold for hot temperature         |
| 15:12          | /          | /           | /                                                                           |
| 11:0           | R/W        | 0x684       | ALARM0_T_HYST<br>Thermal Sensor0 alarm threshold for hysteresis temperature |

### 3.10.6.13. 0x0044 THS1 Alarm Threshold Control Register(Default Value: 0x05A0\_0684)

| Offset: 0x0044 |            |             | Register Name: THS1_ALARM_CTRL                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:28          | /          | /           | /                                                                           |
| 27:16          | R/W        | 0x5A0       | ALARM1_T_HOT<br>Thermal Sensor1 alarm threshold for hot temperature         |
| 15:12          | /          | /           | /                                                                           |
| 11:0           | R/W        | 0x684       | ALARM1_T_HYST<br>Thermal Sensor1 alarm threshold for hysteresis temperature |

### 3.10.6.14. 0x0048 THS2 Alarm Threshold Control Register(Default Value: 0x05A0\_0684)

| Offset: 0x0048 |            |             | Register Name: THS2_ALARM_CTRL                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:28          | /          | /           | /                                                                           |
| 27:16          | R/W        | 0x5A0       | ALARM2_T_HOT<br>Thermal Sensor2 alarm threshold for hot temperature         |
| 15:12          | /          | /           | /                                                                           |
| 11:0           | R/W        | 0x684       | ALARM2_T_HYST<br>Thermal Sensor2 alarm threshold for hysteresis temperature |

### 3.10.6.15. 0x0080 THS0&1 Shutdown Threshold Control Register (Default Value: 0x04E9\_04E9)

| Offset: 0x0080 |            |             | Register Name: THS01_SHUTDOWN_CTRL                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:28          | /          | /           | /                                                                     |
| 27:16          | R/W        | 0x4E9       | SHUT1_T_HOT<br>Thermal Sensor1 shutdown threshold for hot temperature |
| 15:12          | /          | /           | /                                                                     |
| 11:0           | R/W        | 0x4E9       | SHUT0_T_HOT<br>Thermal Sensor0 shutdown threshold for hot temperature |

### 3.10.6.16. 0x0084 THS2 Shutdown Threshold Control Register (Default Value: 0x0000\_04E9)

| Offset: 0x0084 |            |             | Register Name: THS2_SHUTDOWN_CTRL                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:28          | /          | /           | /                                                                     |
| 11:0           | R/W        | 0x4E9       | SHUT2_T_HOT<br>Thermal Sensor2 shutdown threshold for hot temperature |

### 3.10.6.17. 0x00A0 THS0&1 Calibration Data Register (Default Value: 0x0800\_0800)

| Offset: 0x00A0 |            |             | Register Name: THS01_CDATA                     |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31:28          | /          | /           | /                                              |
| 27:16          | R/W        | 0x800       | THS1_CDATA<br>Thermal Sensor1 calibration data |
| 15:12          | /          | /           | /                                              |
| 11:0           | R/W        | 0x800       | THS0_CDATA<br>Thermal Sensor0 calibration data |

### 3.10.6.18. 0x00A4 THS2 Calibration Data Register (Default Value: 0x0000\_0800)

| Offset: 0x00A4 |            |             | Register Name: THS2_CDATA                      |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31:12          | /          | /           | /                                              |
| 11:0           | R/W        | 0x800       | THS2_CDATA<br>Thermal Sensor2 calibration data |

### 3.10.6.19. 0x00C0 THS0 Data Register(Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: THS0_DATA                             |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:12          | /          | /           | /                                                    |
| 11:0           | R          | 0x0         | THS0_DATA<br>Temperature measurement data of sensor0 |

### 3.10.6.20. 0x00C4 THS1 Data Register(Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: THS1_DATA                             |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:12          | /          | /           | /                                                    |
| 11:0           | R          | 0x0         | THS1_DATA<br>Temperature measurement data of sensor1 |

### 3.10.6.21. 0x00C8 THS2 Data Register(Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: THS2_DATA                             |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:12          | /          | /           | /                                                    |
| 11:0           | R          | 0x0         | THS2_DATA<br>Temperature measurement data of sensor2 |

## 3.11. IOMMU

### 3.11.1. Overview

IOMMU(I/O Memory management unit) is designed for product specific memory requirements. It maps the virtual address(sent by peripheral access memory) to the physical address. IOMMU allows multiple ways to manage the location of physical address, and it can use physical address which has potentially conflict mapping for different processes to allocate memory space, and also allow application of non-continuous address mapping to continuous virtual address space.

#### Features:

- Supports virtual address to physical address mapping by hardware implementation
- Supports DE0, VE, CSI, ISP, G2D parallel address mapping
- Supports DE0, VE, CSI, ISP, G2D bypass function independently
- Supports DE0, VE, CSI, ISP, G2D prefetch independently
- Supports DE0, VE, CSI, ISP, G2D 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

### 3.11.2. Block Diagram

The internal module of IOMMU mainly has 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.

**Prefetch Logic:** Each Micro TLB corresponds to a Prefetch 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 memory and stored in the secondary TLB to improve 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 VA 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 hit efficiency and latency.

**APB Interface:** IOMMU register instantiation module. CPU reads and writes the IOMMU register by APB bus.

Figure 3-24 shows the internal block diagram of IOMMU.



Figure 3- 24. IOMMU Block Diagram

Table 3- 10. Correspondence Relation between Master and Module

| Master Number | Module   |
|---------------|----------|
| Master0       | DEO      |
| Master1       | Reserved |
| Master2       | VE       |
| Master3       | CSI      |
| Master4       | ISP      |
| Master5       | G2D      |
| Master6       | Reserved |

### 3.11.3. Operations and Functional Descriptions

#### 3.11.3.1. Clock Sources

IOMMU contains two clock domains in the module. Address mapping is generated by MBUS clock domain, and Register and interrupt processing are generated by APB clock domain. The two domains are asynchronous, and they

are from different clock sources.

### 3.11.3.2. Operation Modes

#### 3.11.3.2.1. Initialization

- Release the IOMMU reset signal by writing 1 to the bit[31] of the **IOMMU Reset Register**;
- Write the base address of the first TLB to the **IOMMU Translation Table Base Register**;
- Set the **IOMMU Interrupt Enable Register**;
- Enable the IOMMU by configuring the **IOMMU Enable Register** in the final.

#### 3.11.3.2.2. Address Changing

In the process of address mapping, The peripheral virtual address VA[31:12] are retrieved in the Level1 TLB, when TLB hits, the mapping finished, or they are retrieved in the Level2 TLB in the same way. If TLB hits, it will write the hit mapping to the Level1 TLB, and hits in Level1 TLB. If Level1 and Level2 TLB are retrieved fail, it will trigger the PTW. After opening peripheral bypass function by setting IOMMU Bypass Register, IOMMU will not map the address for peripheral typed the address, and it will output the virtual address as physical address. The typical application is as follows.

- **Micro TLB hit**
  - a). The master device sends a transfer command, and also sends the address to the corresponding Micro TLB, and searches virtual address corresponding to the Level2 page table;
  - b). If Micro TLB hits, it will return a corresponding physical addresses and the Level2 page table of permission Index;
  - c). Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, transfer is completed.
- **Micro TLB miss, Macro TLB hit**
  - a). The master device sends a transfer command, and also sends the address to the corresponding Micro TLB, and searches virtual address corresponding to the Level2 page table;
  - b). If Micro TLB misses, then continue to search Macro TLB;
  - c). If Macro TLB hits, it will return the Level2 page table to Micro TLB;
  - d). Micro TLB receives the page table, and puts it to Micro TLB(if this Micro TLB is full, there has replace activities), at the same time, sends page table entries to address translation module;
  - e). Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, transfer is completed.
- **Micro TLB miss, Macro TLB miss, PTW Cache hit**
  - a). The master device sends a transfer command, and also sends the address to the corresponding Micro TLB, and searches virtual address corresponding to the Level2 page table;
  - b). If Micro TLB misses, then continue to search Macro TLB;
  - c). If Macro TLB misses, then it will send the request to the PTW to return the corresponding page table;

- d). PTW first accesses PTW Cache, confirms that the required Level1 page table exists in the PTW Cache, sends the page table to PTW logic;
- e). PTW logic returns the corresponding Level2 page table from memory page table according to Level1 page table, checks the effectiveness, and sends to Macro TLB;
- f). Macro TLB stores the Level2 page table (may happen replace activities), and will return the Level2 page table to Micro TLB;
- g). Micro TLB receives the page table entries, puts in the Micro TLB (if this Micro TLB is full, there will happen replace activities), and sends page table entries to address translation module;
- h). Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, transfer is completed.

- **Micro TLB miss, Macro TLB miss, PTW Cache miss**

- a). The master device sends a transfer command, and also sends the address to the corresponding Micro TLB, and searches virtual address corresponding to the Level2 page table;
- b). If Micro TLB misses, then continue to search Macro TLB;
- c). If Macro TLB misses, there will send the request to the PTW to return the corresponding page table;
- d). PTW accesses PTW Cache, there is no necessary Level1 page table;
- e). PTW accesses memory, gets the corresponding Level1 page table and stores in the PTW Cache; (may happen replace activities)
- f). PTW logic returns the corresponding Level2 page table from memory page table according to Level1 page table, checks the effectiveness, and sends to Macro TLB;
- g). Macro TLB stores the Level2 page table (may happen replace activities), and will return the Level 2 page table to Micro TLB;
- h). Micro TLB receives the page table entries, puts in the Micro TLB (if this Micro TLB is full, there will happen replace activities), and sends page table entries to address translation module;
- i). Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, transfer is completed.

- **Permission error**

- a). Permission checking always performs in the address conversion;
- b). Once the permission checking makes mistake, the new access of the master suspends, before this visit continues;
- c). Set the error status register;
- d). Trigger interrupt.

- **Invalid Level1 page table**

- a). Invalid Level1 page table is checked when PTW logic reads the new level page table from memory;
- b). The PTW read sequentially two page table entries from the memory (64-bit data, a complete cache line), and stores in the PTW cache;
- c). If the current page table is detected invalid, then the error flag is set, and the interrupt is triggered, the cache line need to be invalidated.

**NOTE**

**Invalid page table has two situations: the reading target page table from the memory is invalid; and the page table stored in PTW Cache with target page table is found to be invalid after using;**

**If a page table is invalid, then total cache line( that is two page tables) need to be invalidated.**

- **Invalid Level2 page table**

- a). Invalid Level2 page table checks when Macro TLB reads the new level page table from memory;
- b). The Macro TLB read sequentially two page table entries from the memory (64-bit data, a complete cache line), and stores in the Macro TLB;
- c). If the current page table is detected invalid, then the error flag is set, and the interrupt is triggered, the cache line need to be invalidated.

**NOTE**

**Invalid page table has two situations: the reading target page table from the memory is invalid; and the page table stored in Macro TLB with target page table is found to be invalid after using.**

**If a page table is invalid, then total cache line(that is two page tables) need to be invalidated.**

The internal address switch process shows in Figure 3-25.



Figure 3- 25. Internal Switch Process

### 3.11.3.2.3. VA-PA Mapping

IOMMU page table is defined as 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 size. IOMMU supports a page table only, its 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 the page table is defined by software, and it needs 16 KB address alignment; Page table of the Level2 table item needs 1 KB address alignment. A complete VA-PA address translation process is shown in Figure 3-26.



Figure 3- 26. VA-PA Switch Process

#### 3.11.3.2.4. Clear and Invalidate TLB

When multi page table content refresh, or table address changes, all VA-PA mapping which has been cached in TLB will no longer be valid, then you need configure **IOMMU TLB Flush Enable Register** to clear the TLB or PTW Cache. First suspend access to TLB or Cache, then configure the corresponding Flush bit of **IOMMU TLB Flush Enable Register**, after operation takes effect, related peripherals can continue to send new access memory operations.

When some page table is invalid or incorrect mapping, you can set the TLB Invalidation relevant register to invalidate TLB VA-PA mapping pairs. The invalid TLB supports two modes.

## (1) Mode0

Firstly, set **IOMMU TLB Invalid Mode Select Register** to 0 to select mode0;

Secondly, write target address to **IOMMU TLB Invalid Address Register**;

Thirdly, set configuration values to **IOMMU TLB Invalid Address Mask Register**, the requirements are as follows:

- The value of **IOMMU TLB Invalid Address Mask Register** cannot be less than the **IOMMU TLB Invalid Address Register**.
- The higher bit of **IOMMU TLB Invalid Address Mask Register** must be continuous 1, the lower bit must be continuous 0, for example, 0xfffff000, 0xffffe000, 0xfffffc000, 0xfffff8000, 0xfffff0000 belongs to the legal value; and 0xfffffd000, 0xfffffb000, 0xfffffa000, 0xfffff9000, 0xfffff7000 belongs to illegal values.

Finally, configure **IOMMU TLB Invalid Enable Register** to enable invalid operation. Among the way to determine the invalid address is to get maximum valid bit and determine target address range by target address AND mask address. The process is shown as follows.



Figure 3- 27. Invalid TLB Address Range

For example:

- When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFF000 by default, the result of AND is target address, that is, only target address is invalid.
- When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFF0000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE1000, then target address range is from 0xEEEE0000 to 0xEEEF000.
- When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFFC000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE8000, then target address range is from 0xEEEE8000 to 0xEEEB000.
- When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFF8000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEC000, then target address range is from 0xEEEE8000 to 0xEEEF000.
- When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFC000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE0000, then target address range is from 0xEEEE0000 to 0xEEE3000.

## (2) Mode1

Firstly, set **IOMMU TLB Invalid Mode Select Register** to 1 to select mode1;

Secondly, set the starting address of invalid TLB by **IOMMU TLB Invalidation Start Address Register**, and set the ending address of invalid TLB by **IOMMU TLB Invalidation Start Address Register**;

Finally, configure **IOMMU TLB Invalidation Enable Register** to enable invalid operation, then invalid related TLB operation can be completed.

### 3.11.3.3. Page Table Format

#### 3.11.3.3.1. Level1 Page Table

The format of Level1 page table is as follows.

|    |                                    |          |       |
|----|------------------------------------|----------|-------|
| 31 | Start address of Level2 page table | 10 9     | 2 1 0 |
|    |                                    | Reserved | 01    |

Figure 3- 28. Level1 Page Table Format

Bit[31:10]: Base address of Level2 page table;

Bit[9:2]: Reserved;

Bit[1:0]: 01 is valid page table; others are fault;

#### 3.11.3.3.2. Level2 Page Table

The format of Level2 page table is as follows.

|    |                       |    |     |   |     |
|----|-----------------------|----|-----|---|-----|
| 31 | Physical base address | 12 | 7   | 4 | 1 0 |
|    |                       |    | ACI |   | 1   |

Figure 3- 29. Level1 Page Table Format

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 valid page table; 0 is fault;

Bit[0]: Reserved

#### 3.11.3.3.3. Permission Index

The read/write access control of series register such as **IOMMU Domain Authority Control Register** is as follows.

| 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| W  | R  | W  | R  | W | R | W | R | W | R | W | R | W | R |

Figure 3- 30. Read/Write Permission Control

Bit[1:0]/Bit[17:16]: Master0 read/write permission control;

Bit[3:2]/Bit[19:18]: Master1 read/write permission control;  
 Bit[5:4]/Bit[21:20]: Master2 read/write permission control;  
 Bit[7:6]/Bit[23:22]: Master3 read/write permission control;  
 Bit[9:8]/Bit[25:24]: Master4 read/write permission control;  
 Bit[11:10]/Bit[27:26]: Master5 read/write permission control;  
 Bit[13:12]/Bit[29:28]: Master6 read/write permission control.

The value of **IOMMU Domain Authority Control Register** is read-only by default. Other registers can configure through system requirement. In address switch process, the corresponding relation between ACI and Domain is as follows.

**Table 3- 11. Relation between ACI and Domain**

| ACI | Domain    | Register                                  |
|-----|-----------|-------------------------------------------|
| 0   | Domain 0  | IOMMU Domain Authority Control Register 0 |
| 1   | Domain 1  | IOMMU Domain Authority Control Register 0 |
| 2   | Domain 2  | IOMMU Domain Authority Control Register 1 |
| 3   | Domain 3  | IOMMU Domain Authority Control Register 1 |
| 4   | Domain 4  | IOMMU Domain Authority Control Register 2 |
| 5   | Domain 5  | IOMMU Domain Authority Control Register 2 |
| 6   | Domain 6  | IOMMU Domain Authority Control Register 3 |
| 7   | Domain 7  | IOMMU Domain Authority Control Register 3 |
| 8   | Domain 8  | IOMMU Domain Authority Control Register 4 |
| 9   | Domain 9  | IOMMU Domain Authority Control Register 4 |
| 10  | Domain 10 | IOMMU Domain Authority Control Register 5 |
| 11  | Domain 11 | IOMMU Domain Authority Control Register 5 |
| 12  | Domain 12 | IOMMU Domain Authority Control Register 6 |
| 13  | Domain 13 | IOMMU Domain Authority Control Register 6 |
| 14  | Domain 14 | IOMMU Domain Authority Control Register 7 |
| 15  | Domain 15 | IOMMU Domain Authority Control Register 7 |

After enabled **IOMMU Domain Authority Overwrite Register**, the read/write control permission can override all **IOMMU Domain Authority Control Register**.

### 3.11.4. Programming Guidelines

#### 3.11.4.1. IOMMU Reset

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.

#### 3.11.4.2. IOMMU Enable

Before opening the IOMMU address mapping function, Translation Table Base register should be correctly configured, or all the masters are in the bypass state, or all the masters do not send the bus command.

### 3.11.4.3. Configure TTB

Operating the register must close IOMMU address mapping function, namely IOMMU\_ENABLE\_REG [0] is 0; or Bypass function of all masters is set to 1, or no the state of transfer bus commands.

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

### 3.11.4.5. Read/Write VA Data

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

### 3.11.4.6. PMU Statistics

When PMU function is used for the first time, set **IOMMU PMU Enable Register** to enable statistics function; when reading the relevant Register, clear the enable bit of **IOMMU PMU Enable Register**; when PMU function is used next time, first **IOMMU PMU Clear Register** is set, after counter is cleared, set the enable bit of **IOMMU PMU Enable Register**.

Given a Level2 page table administers continuous 4KB address, if Micro TLB misses in continuous virtual address, there may need to return a Level2 page table to hit from Macro TLB; 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

## 3.11.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| IOMMU       | 0x030F0000   |

| Register Name                | Offset | Description                                     |
|------------------------------|--------|-------------------------------------------------|
| IOMMU_RESET_REG              | 0x0010 | IOMMU ResetRegister                             |
| IOMMU_ENABLE_REG             | 0x0020 | IOMMU EnableRegister                            |
| IOMMU_BYPASS_REG             | 0x0030 | IOMMU BypassRegister                            |
| IOMMU_AUTO_GATING_REG        | 0x0040 | IOMMU Auto GatingRegister                       |
| 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 BaseRegister            |
| IOMMU_TLB_ENABLE_REG         | 0x0060 | IOMMU TLB EnableRegister                        |
| IOMMU_TLB_PREFETCH_REG       | 0x0070 | IOMMU TLB PrefetchRegister                      |
| 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 Invalidatation Start Address Register |
| IOMMU_TLB_IVLD_END_ADDR_REG  | 0x008C | IOMMU TLB Invalidatation End Address Register   |
| IOMMU_TLB_IVLD_ADDR_REG      | 0x0090 | IOMMU TLB Invalidatation Address Register       |
| IOMMU_TLB_IVLD_ADDR_MASK_REG | 0x0094 | IOMMU TLB Invalidatation Address Mask Register  |
| IOMMU_TLB_IVLD_ENABLE_REG    | 0x0098 | IOMMU TLB Invalidatation Enable Register        |
| IOMMU_PC_IVLD_ADDR_REG       | 0x00A0 | IOMMU PC Invalidatation Address Register        |
| IOMMU_PC_IVLD_ENABLE_REG     | 0x00A8 | IOMMU PC Invalidatation Enable Register         |
| IOMMU_DM_AUT_CTRL_REG0       | 0x00B0 | IOMMU Domain Authority Control Register 0       |
| IOMMU_DM_AUT_CTRL_REG1       | 0x00B4 | IOMMU Domain Authority Control Register 1       |
| IOMMU_DM_AUT_CTRL_REG2       | 0x00B8 | IOMMU Domain Authority Control Register 2       |
| IOMMU_DM_AUT_CTRL_REG3       | 0x00BC | IOMMU Domain Authority Control Register 3       |
| IOMMU_DM_AUT_CTRL_REG4       | 0x00C0 | IOMMU Domain Authority Control Register 4       |
| IOMMU_DM_AUT_CTRL_REG5       | 0x00C4 | IOMMU Domain Authority Control Register 5       |
| IOMMU_DM_AUT_CTRL_REG6       | 0x00C8 | IOMMU Domain Authority Control Register 6       |
| IOMMU_DM_AUT_CTRL_REG7       | 0x00CC | IOMMU Domain Authority Control Register 7       |
| IOMMU_DM_AUT_OVWT_REG        | 0x00D0 | IOMMU Domain Authority Overwrite 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_ADDR_REG0      | 0x0110 | IOMMU Interrupt Error Address Register 0        |
| IOMMU_INT_ERR_ADDR_REG1      | 0x0114 | IOMMU Interrupt Error Address Register 1        |
| IOMMU_INT_ERR_ADDR_REG2      | 0x0118 | IOMMU Interrupt Error Address Register 2        |
| IOMMU_INT_ERR_ADDR_REG3      | 0x011C | IOMMU Interrupt Error Address Register 3        |
| IOMMU_INT_ERR_ADDR_REG4      | 0x0120 | IOMMU Interrupt Error Address Register 4        |
| IOMMU_INT_ERR_ADDR_REG5      | 0x0124 | IOMMU Interrupt Error Address Register 5        |
| IOMMU_INT_ERR_ADDR_REG6      | 0x0128 | IOMMU Interrupt Error Address Register 6        |
| IOMMU_INT_ERR_ADDR_REG7      | 0x0130 | IOMMU Interrupt Error Address Register 7        |
| IOMMU_INT_ERR_ADDR_REG8      | 0x0134 | IOMMU Interrupt Error Address Register 8        |
| IOMMU_INT_ERR_DATA_REG0      | 0x0150 | IOMMU Interrupt Error Data Register 0           |

|                            |        |                                              |
|----------------------------|--------|----------------------------------------------|
| IOMMU_INT_ERR_DATA_REG1    | 0x0154 | IOMMU Interrupt Error Data Register 1        |
| IOMMU_INT_ERR_DATA_REG2    | 0x0158 | IOMMU Interrupt Error Data Register 2        |
| IOMMU_INT_ERR_DATA_REG3    | 0x015C | IOMMU Interrupt Error Data Register 3        |
| IOMMU_INT_ERR_DATA_REG4    | 0x0160 | IOMMU Interrupt Error Data Register 4        |
| IOMMU_INT_ERR_DATA_REG5    | 0x0164 | IOMMU Interrupt Error Data Register 5        |
| IOMMU_INT_ERR_DATA_REG6    | 0x0168 | IOMMU Interrupt Error Data Register 6        |
| IOMMU_INT_ERR_DATA_REG7    | 0x0170 | IOMMU Interrupt Error Data Register 7        |
| IOMMU_INT_ERR_DATA_REG8    | 0x0174 | IOMMU Interrupt Error Data Register 8        |
| 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                    |
| IOMMU_PMU_CLR_REG          | 0x0210 | IOMMU PMU Clear Register                     |
| IOMMU_PMU_ACCESS_LOW_REG0  | 0x0230 | IOMMU PMU Access Low Register 0              |
| IOMMU_PMU_ACCESS_HIGH_REG0 | 0x0234 | IOMMU PMU Access High Register 0             |
| IOMMU_PMU_HIT_LOW_REG0     | 0x0238 | IOMMU PMU Hit Low Register 0                 |
| IOMMU_PMU_HIT_HIGH_REG0    | 0x023C | IOMMU PMU Hit High Register 0                |
| IOMMU_PMU_ACCESS_LOW_REG1  | 0x0240 | IOMMU PMU Access Low Register 1              |
| IOMMU_PMU_ACCESS_HIGH_REG1 | 0x0244 | IOMMU PMU Access High Register 1             |
| IOMMU_PMU_HIT_LOW_REG1     | 0x0248 | IOMMU PMU Hit Low Register 1                 |
| IOMMU_PMU_HIT_HIGH_REG1    | 0x024C | IOMMU PMU Hit High Register 1                |
| IOMMU_PMU_ACCESS_LOW_REG2  | 0x0250 | IOMMU PMU Access Low Register 2              |
| IOMMU_PMU_ACCESS_HIGH_REG2 | 0x0254 | IOMMU PMU Access High Register 2             |
| IOMMU_PMU_HIT_LOW_REG2     | 0x0258 | IOMMU PMU Hit Low Register 2                 |
| IOMMU_PMU_HIT_HIGH_REG2    | 0x025C | IOMMU PMU Hit High Register 2                |
| IOMMU_PMU_ACCESS_LOW_REG3  | 0x0260 | IOMMU PMU Access Low Register 3              |
| IOMMU_PMU_ACCESS_HIGH_REG3 | 0x0264 | IOMMU PMU Access High Register 3             |
| IOMMU_PMU_HIT_LOW_REG3     | 0x0268 | IOMMU PMU Hit Low Register 3                 |
| IOMMU_PMU_HIT_HIGH_REG3    | 0x026C | IOMMU PMU Hit High Register 3                |
| IOMMU_PMU_ACCESS_LOW_REG4  | 0x0270 | IOMMU PMU Access Low Register 4              |
| IOMMU_PMU_ACCESS_HIGH_REG4 | 0x0274 | IOMMU PMU Access High Register 4             |
| IOMMU_PMU_HIT_LOW_REG4     | 0x0278 | IOMMU PMU Hit Low Register 4                 |
| IOMMU_PMU_HIT_HIGH_REG4    | 0x027C | IOMMU PMU Hit High Register 4                |
| IOMMU_PMU_ACCESS_LOW_REG5  | 0x0280 | IOMMU PMU Access Low Register 5              |
| IOMMU_PMU_ACCESS_HIGH_REG5 | 0x0284 | IOMMU PMU Access High Register 5             |
| IOMMU_PMU_HIT_LOW_REG5     | 0x0288 | IOMMU PMU Hit Low Register 5                 |
| IOMMU_PMU_HIT_HIGH_REG5    | 0x028C | IOMMU PMU Hit High Register 5                |
| IOMMU_PMU_ACCESS_LOW_REG6  | 0x0290 | IOMMU PMU Access Low Register 6              |
| IOMMU_PMU_ACCESS_HIGH_REG6 | 0x0294 | IOMMU PMU Access High Register 6             |
| IOMMU_PMU_HIT_LOW_REG6     | 0x0298 | IOMMU PMU Hit Low Register 6                 |
| IOMMU_PMU_HIT_HIGH_REG6    | 0x029C | IOMMU PMU Hit High Register 6                |
| IOMMU_PMU_ACCESS_LOW_REG7  | 0x02D0 | IOMMU PMU Access Low Register 7              |

|                            |        |                                     |
|----------------------------|--------|-------------------------------------|
| IOMMU_PMU_ACCESS_HIGH_REG7 | 0x02D4 | IOMMU PMU Access High Register 7    |
| IOMMU_PMU_HIT_LOW_REG7     | 0x02D8 | IOMMU PMU Hit Low Register 7        |
| IOMMU_PMU_HIT_HIGH_REG7    | 0x02DC | IOMMU PMU Hit High Register 7       |
| IOMMU_PMU_ACCESS_LOW_REG8  | 0x02E0 | IOMMU PMU Access Low Register 8     |
| IOMMU_PMU_ACCESS_HIGH_REG8 | 0x02E4 | IOMMU PMU Access High Register 8    |
| IOMMU_PMU_HIT_LOW_REG8     | 0x02E8 | IOMMU PMU Hit Low Register 8        |
| IOMMU_PMU_HIT_HIGH_REG8    | 0x02EC | IOMMU PMU Hit High Register 8       |
| IOMMU_PMU_TL_LOW_REG0      | 0x0300 | IOMMU Total Latency Low Register 0  |
| IOMMU_PMU_TL_HIGH_REG0     | 0x0304 | IOMMU Total Latency High Register 0 |
| IOMMU_PMU_ML_REG0          | 0x0308 | IOMMU Max Latency Register 0        |
| IOMMU_PMU_TL_LOW_REG1      | 0x0310 | IOMMU Total Latency Low Register 1  |
| IOMMU_PMU_TL_HIGH_REG1     | 0x0314 | IOMMU Total Latency High Register 1 |
| IOMMU_PMU_ML_REG1          | 0x0318 | IOMMU Max Latency Register 1        |
| IOMMU_PMU_TL_LOW_REG2      | 0x0320 | IOMMU Total Latency Low Register 2  |
| IOMMU_PMU_TL_HIGH_REG2     | 0x0324 | IOMMU Total Latency High Register 2 |
| IOMMU_PMU_ML_REG2          | 0x0328 | IOMMU Max Latency Register 2        |
| IOMMU_PMU_TL_LOW_REG3      | 0x0330 | IOMMU Total Latency Low Register 3  |
| IOMMU_PMU_TL_HIGH_REG3     | 0x0334 | IOMMU Total Latency High Register 3 |
| IOMMU_PMU_ML_REG3          | 0x0338 | IOMMU Max Latency Register 3        |
| IOMMU_PMU_TL_LOW_REG4      | 0x0340 | IOMMU Total Latency Low Register 4  |
| IOMMU_PMU_TL_HIGH_REG4     | 0x0344 | IOMMU Total Latency High Register 4 |
| IOMMU_PMU_ML_REG4          | 0x0348 | IOMMU Max Latency Register 4        |
| IOMMU_PMU_TL_LOW_REG5      | 0x0350 | IOMMU Total Latency Low Register 5  |
| IOMMU_PMU_TL_HIGH_REG5     | 0x0354 | IOMMU Total Latency High Register 5 |
| IOMMU_PMU_ML_REG5          | 0x0358 | IOMMU Max Latency Register 5        |
| IOMMU_PMU_TL_LOW_REG6      | 0x0360 | IOMMU Total Latency Low Register 6  |
| IOMMU_PMU_TL_HIGH_REG6     | 0x0364 | IOMMU Total Latency High Register 6 |
| IOMMU_PMU_ML_REG6          | 0x0368 | IOMMU Max Latency Register 6        |

### 3.11.6. Register Description

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

|       |     |     |                                                                                                                                                                                                                           |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:18 | /   | /   | /                                                                                                                                                                                                                         |
| 17    | R/W | 0x1 | <p>PTW_CACHE_RESET<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, the bit is used to reset PTW Cache individually.</p> |
| 16    | R/W | 0x1 | <p>MACRO_TLB_RESET<br/>Macro TLB address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When PTW Cache occurs abnormal, the bit is used to reset PTW Cache individually.</p> |
| 15:7  | /   | /   | /                                                                                                                                                                                                                         |
| 6     | R/W | 0x1 | <p>MASTER6_RESET<br/>Master6 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master6 occurs abnormal, the bit is used to reset PTW Cache individually.</p>       |
| 5     | R/W | 0x1 | <p>MASTER5_RESET<br/>Master5 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master5 occurs abnormal, the bit is used to reset PTW Cache individually.</p>       |
| 4     | R/W | 0x1 | <p>MASTER4_RESET<br/>Master4 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master4 occurs abnormal, the bit is used to reset PTW Cache individually.</p>       |
| 3     | R/W | 0x1 | <p>MASTER3_RESET<br/>Master3 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master3 occurs abnormal, the bit is used to reset PTW Cache individually.</p>       |
| 2     | R/W | 0x1 | <p>MASTER2_RESET<br/>Master2 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master2 occurs abnormal, the bit is used to reset PTW Cache individually.</p>       |
| 1     | R/W | 0x1 | MASTER1_RESET                                                                                                                                                                                                             |

|   |     |     |                                                                                                                                                                                                          |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Master1 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master1 occurs abnormal, the bit is used to reset PTW Cache individually.                  |
| 0 | R/W | 0x1 | MASTER0_RESET<br>Master0 address convert lane software reset switch.<br>0: Set reset signal<br>1: Release reset signal<br>When Master0 occurs abnormal, the bit is used to reset PTW Cache individually. |

### 3.11.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         | ENABLE<br>IOMMU module enable switch<br>0: Disable IOMMU<br>1: Enable IOMMU<br>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) |

### 3.11.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         | MASTER6_BYPASS<br>Master6 bypass switch<br>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.<br>0: Disable bypass function<br>1: Enable bypass function |
| 5              | R/W        | 0x1         | MASTER5_BYPASS<br>Master5 bypass switch<br>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.<br>0: Disable bypass function                              |

|   |     |     |                                                                                                                                                                                                                                                                             |
|---|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: Enable bypass function                                                                                                                                                                                                                                                   |
| 4 | R/W | 0x1 | <p>MASTER4_BYPASS<br/>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.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 3 | R/W | 0x1 | <p>MASTER3_BYPASS<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.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 2 | R/W | 0x1 | <p>MASTER2_BYPASS<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.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 1 | R/W | 0x1 | <p>MASTER1_BYPASS<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.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 0 | R/W | 0x1 | <p>MASTER0_BYPASS<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.</p> <p>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 after the 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 .**

### 3.11.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 decreasing power consumption of the module.<br>0: Disable auto gating function<br>1: Enable auto gating function |

### 3.11.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         | MASTER5_WBUF_CTRL<br>Master5 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer<br><b>Note: G2D does not write buffer, so the bit is invalid.</b> |
| 4              | R/W        | 0x1         | MASTER4_WBUF_CTRL<br>Master4 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer                                                                   |
| 3              | R/W        | 0x1         | MASTER3_WBUF_CTRL<br>Master3 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer                                                                   |
| 2              | R/W        | 0x1         | MASTER2_WBUF_CTRL<br>Master2 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer                                                                   |
| 1              | R/W        | 0x1         | MASTER1_WBUF_CTRL<br>Master1 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer                                                                   |
| 0              | R/W        | 0x1         | MASTER0_WBUF_CTRL<br>Master0 write buffer control bit<br>0: Disable write buffer<br>1: Enable write buffer                                                                   |

### 3.11.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         | MASTER6_OOO_CTRL<br>Master6 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 5              | R/W        | 0x1         | MASTER5_OOO_CTRL<br>Master5 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 4              | R/W        | 0x1         | MASTER4_OOO_CTRL<br>Master4 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 3              | R/W        | 0x1         | MASTER3_OOO_CTRL<br>Master3 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 2              | R/W        | 0x1         | MASTER2_OOO_CTRL<br>Master2 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 1              | R/W        | 0x1         | MASTER1_OOO_CTRL<br>Master1 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 0              | R/W        | 0x1         | MASTER0_OOO_CTRL<br>Master0 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |

### 3.11.6.7. 0x004C IOMMU 4KB Boundary Protect Control Register (Default Value: 0x0000\_007F)

| Offset: 0x004C |            |             | Register Name: IOMMU_4KB_BDY_PRT_CTRL_REG                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:7           | /          | /           | /                                                                                                                                         |
| 6              | R/W        | 0x1         | MASTER6_4KB_BDY_PRT_CTRL<br>Master6 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |

|   |     |     |                                                                                                                                           |
|---|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | R/W | 0x1 | MASTER5_4KB_BDY_PRT_CTRL<br>Master4 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |
| 4 | R/W | 0x1 | MASTER4_4KB_BDY_PRT_CTRL<br>Master4 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |
| 3 | R/W | 0x1 | MASTER3_4KB_BDY_PRT_CTRL<br>Master3 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |
| 2 | R/W | 0x1 | MASTER2_4KB_BDY_PRT_CTRL<br>Master2 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |
| 1 | R/W | 0x1 | MASTER1_4KB_BDY_PRT_CTRL<br>Master1 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |
| 0 | R/W | 0x1 | MASTER0_4KB_BDY_PRT_CTRL<br>Master0 4KB boundary protect control bit<br>0: Disable 4KB boundary protect<br>1: Enable 4KB boundary protect |

**NOTE**

When the virtual address sent by master is over the 4KB boundary, 4KB protection unit will split it into two serial access.

### 3.11.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>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; Or Bypass function of all main equipment is set to 1, or no the state of transfer bus commands (such as setting). |
| 13:0           | /          | /           | /                                                                                                                                                                                                                                                                                           |

## 3.11.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         | PTW_CACHE_ENABLE<br>PTW Cache enable bit<br>0: Disable<br>1: Enable   |
| 16             | R/W        | 0x1         | MACRO_TLB_ENABLE<br>Macro 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         | MICRO_TLB1_ENABLE<br>Micro TLB1 enable bit<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x1         | MICRO_TLB0_ENABLE<br>Micro TLB0 enable bit<br>0: Disable<br>1: Enable |

### 3.11.6.10. 0x0070 IOMMU TLB Prefetch Register (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31:7           | /          | /           | /                                                                                                                                                                  |
| 6              | R/W        | 0x0         | MICRO_TLB6_PREFETCH<br>Micro TLB6 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |
| 5              | R/W        | 0x0         | MICRO_TLB5_PREFETCH<br>Micro TLB5 prefetch enable<br>0: Disable<br>1: Enable<br><b>Note:</b> When G2D accesses DDR, the prefetch function is suggested to disable. |
| 4              | R/W        | 0x0         | MICRO_TLB4_PREFETCH<br>Micro TLB4 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |
| 3              | R/W        | 0x0         | MICRO_TLB3_PREFETCH<br>Micro TLB3 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |
| 2              | R/W        | 0x0         | MICRO_TLB2_PREFETCH<br>Micro TLB2 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |
| 1              | R/W        | 0x0         | MICRO_TLB1_PREFETCH<br>Micro TLB1 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |
| 0              | R/W        | 0x0         | MICRO_TLB0_PREFETCH<br>Micro TLB0 prefetch enable<br>0: Disable<br>1: Enable                                                                                       |

### 3.11.6.11. 0x0080 IOMMU TLB Flush Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:18          | /          | /           | /                                                                                        |
| 17             | R/WAC      | 0x0         | PTW_CACHE_FLUSH<br>Clear PTW Cache<br>0: No clear operation or clear operation completed |

|      |       |     |                                                                                                                                                                                           |
|------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |       |     | 1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically.                                                                                               |
| 16   | R/WAC | 0x0 | MACRO_TLB_FLUSH<br>Clear Macro TLB<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically.   |
| 15:7 | /     | /   | /                                                                                                                                                                                         |
| 6    | R/WAC | 0x0 | MICRO_TLB6_FLUSH<br>Clear Micro TLB6<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 5    | R/WAC | 0x0 | MICRO_TLB5_FLUSH<br>Clear Micro TLB5<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 4    | R/WAC | 0x0 | MICRO_TLB4_FLUSH<br>Clear Micro TLB4<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 3    | R/WAC | 0x0 | MICRO_TLB3_FLUSH<br>Clear Micro TLB3<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 2    | R/WAC | 0x0 | MICRO_TLB2_FLUSH<br>Clear Micro TLB2<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 1    | R/WAC | 0x0 | MICRO_TLB1_FLUSH<br>Clear Micro TLB1<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |
| 0    | R/WAC | 0x0 | MICRO_TLB0_FLUSH<br>Clear Micro TLB0<br>0: No clear operation or clear operation completed<br>1: Enable is cleared<br>After Flush operation completes, the bit can clear 0 automatically. |



## NOTE

When performing flush operation, all TLB/Cache access will be paused.

Before flush starts, the operation that has entered TLB continues to complete.

### 3.11.6.12. 0x0084 IOMMU TLB Invalid 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<br>0: Use invalid TLB with Mask mode<br>1: Use invalid TLB with Start and End mode |

### 3.11.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_STA_ADDR<br>TLB invalid address, 4KB aligned. |
| 11:0           | /          | /           | /                                                      |

### 3.11.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_END_ADDR<br>TLB invalid address, 4KB aligned. |
| 11:0           | /          | /           | /                                                      |

### 3.11.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, 4KB aligned |
| 11:0           | /          | /           | /                                                 |

#### Operation:

- 1) Set the virtual address which needs to be operated in IOMMU\_TLB\_IVLD\_ADDR\_REG.
- 2) Set the mask of virtual address which needs to be operated in IOMMU\_TLB\_IVLD\_ADDR\_MASK\_REG.
- 3) Write '1' to IOMMU\_TLB\_IVLD\_ENABLE\_REG[0].
- 4) 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 starts, there is no absolute relationship between same address switch operation and Invalidiation operation.

### 3.11.6.16. 0x0094 IOMMU TLB Invalidation 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 register, 4KB aligned |
| 11:0           | /          | /           | /                                                                    |

### 3.11.6.17. 0x0098 IOMMU TLB Invalidation 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 invalid operation<br>0: No-operation or operation completed<br>1: Enable is invalid<br>After invalidation operation completed, the bit can clear 0 automatically.<br>When operating Invalidation, TLB/Cache operation has not affected.<br>After or Before Invalidation starts, there is no absolute relationship between same address switch operation and Invalidation operation. |

### 3.11.6.18. 0x00A0 IOMMU PC Invalidation 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, 1MB aligned. |
| 19:0           | /          | /           | /                                                       |

### 3.11.6.19. 0x00A8 IOMMU PC Invalidation 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         | <p>PC_IVLD_ENABLE<br/>Enable PTW Cache invalid operation<br/>0: No-operation or operation completed<br/>1: Enable is invalid<br/>After invalidation operation completed, the bit can clear 0 automatically.<br/>After or Before Invalidiation starts, there is no absolute relationship between same address switch operation and Invalidiation operation.</p> |

### 3.11.6.20. 0x00B0 IOMMU Domain Authority Control Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG0                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31:30          | /          | /           | /                                                                                                                                                           |
| 29             | R/W        | 0x0         | <p>DM1_M6_WT_AUT_CTRL<br/>Domain1 write permission control for master6<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> |
| 28             | R/W        | 0x0         | <p>DM1_M6_RD_AUT_CTRL<br/>Domain1 read permission control for master6<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>    |
| 27             | R/W        | 0x0         | <p>DM1_M5_WT_AUT_CTRL<br/>Domain1 write permission control for master5<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> |
| 26             | R/W        | 0x0         | <p>DM1_M5_RD_AUT_CTRL<br/>Domain1 read permission control for master5<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>    |
| 25             | R/W        | 0x0         | <p>DM1_M4_WT_AUT_CTRL<br/>Domain1 write permission control for master4<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> |
| 24             | R/W        | 0x0         | <p>DM1_M4_RD_AUT_CTRL<br/>Domain1 read permission control for master4<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>    |
| 23             | R/W        | 0x0         | <p>DM1_M3_WT_AUT_CTRL<br/>Domain1 write permission control for master3<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> |
| 22             | R/W        | 0x0         | DM1_M3_RD_AUT_CTRL                                                                                                                                          |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | Domain1 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                          |
| 21    | R/W | 0x0 | DM1_M2_WT_AUT_CTRL<br>Domain1 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20    | R/W | 0x0 | DM1_M2_RD_AUT_CTRL<br>Domain1 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM1_M1_WT_AUT_CTRL<br>Domain1 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM1_M1_RD_AUT_CTRL<br>Domain1 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM1_M0_WT_AUT_CTRL<br>Domain1 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM1_M0_RD_AUT_CTRL<br>Domain1 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                 |
| 13    | R   | 0x0 | DM0_M6_WT_AUT_CTRL<br>Domain0 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R   | 0x0 | DM0_M6_RD_AUT_CTRL<br>Domain0 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R   | 0x0 | DM0_M5_WT_AUT_CTRL<br>Domain0 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R   | 0x0 | DM0_M5_RD_AUT_CTRL<br>Domain0 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R   | 0x0 | DM0_M4_WT_AUT_CTRL                                                                                                                                |

|   |   |     |                                                                                                                                                   |
|---|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | Domain0 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                       |
| 8 | R | 0x0 | DM0_M4_RD_AUT_CTRL<br>Domain0 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7 | R | 0x0 | DM0_M3_WT_AUT_CTRL<br>Domain0 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6 | R | 0x0 | DM0_M3_RD_AUT_CTRL<br>Domain0 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5 | R | 0x0 | DM0_M2_WT_AUT_CTRL<br>Domain0 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4 | R | 0x0 | DM0_M2_RD_AUT_CTRL<br>Domain0 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3 | R | 0x0 | DM0_M1_WT_AUT_CTRL<br>Domain0 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R | 0x0 | DM0_M1_RD_AUT_CTRL<br>Domain0 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R | 0x0 | DM0_M0_WT_AUT_CTRL<br>Domain0 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R | 0x0 | DM0_M0_RD_AUT_CTRL<br>Domain0 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

**NOTE**

Software can be set up 15 different permission control types , which are set in IOMMU\_DM\_AUT\_CTRL\_REG0 ~ 7. As well as a default access control type, domain0. The read/write operation of DOMIAN1 ~ 15 is unlimited by default.

Software needs to set the corresponding permission control domain index of the page table item in the secondary

page table entries[7:4], the default value is 0, use domain0, namely the read/write operation is not controlled. Setting REG\_ARD\_OVWT can mask the Domain control defined by IOMMU\_DM\_AUT\_CTRL\_REG0~7. All Level2 page table type are covered by the type of REG\_ARD\_OVWT. The read/write operation is permitted by default.

### 3.11.6.21. 0x00B4 IOMMU Domain Authority Control Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG1                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                 |
| 29             | R/W        | 0x0         | DM3_M6_WT_AUT_CTRL<br>Domain3 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM3_M6_RD_AUT_CTRL<br>Domain3 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM3_M5_WT_AUT_CTRL<br>Domain3 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM3_M5_RD_AUT_CTRL<br>Domain3 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM3_M4_WT_AUT_CTRL<br>Domain3 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24             | R/W        | 0x0         | DM3_M4_RD_AUT_CTRL<br>Domain3 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM3_M3_WT_AUT_CTRL<br>Domain3 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM3_M3_RD_AUT_CTRL<br>Domain3 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM3_M2_WT_AUT_CTRL<br>Domain3 write permission control for master2<br>0: The write-operation is permitted                                         |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: The write-operation is prohibited                                                                                                              |
| 20    | R/W | 0x0 | DM3_M2_RD_AUT_CTRL<br>Domain3 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM3_M1_WT_AUT_CTRL<br>Domain3 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM3_M1_RD_AUT_CTRL<br>Domain3 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM3_M0_WT_AUT_CTRL<br>Domain3 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM3_M0_RD_AUT_CTRL<br>Domain3 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                 |
| 13    | R/W | 0x0 | DM2_M6_WT_AUT_CTRL<br>Domain2 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM2_M6_RD_AUT_CTRL<br>Domain2 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R/W | 0x0 | DM2_M5_WT_AUT_CTRL<br>Domain2 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R/W | 0x0 | DM2_M5_RD_AUT_CTRL<br>Domain2 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R/W | 0x0 | DM2_M4_WT_AUT_CTRL<br>Domain2 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8     | R/W | 0x0 | DM2_M4_RD_AUT_CTRL<br>Domain2 read permission control for master4<br>0: The read-operation is permitted                                           |

|   |     |     |                                                                                                                                                   |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: The read-operation is prohibited                                                                                                               |
| 7 | R/W | 0x0 | DM2_M3_WT_AUT_CTRL<br>Domain2 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6 | R/W | 0x0 | DM2_M3_RD_AUT_CTRL<br>Domain2 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5 | R/W | 0x0 | DM2_M2_WT_AUT_CTRL<br>Domain2 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4 | R/W | 0x0 | DM2_M2_RD_AUT_CTRL<br>Domain2 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3 | R/W | 0x0 | DM2_M1_WT_AUT_CTRL<br>Domain2 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R/W | 0x0 | DM2_M1_RD_AUT_CTRL<br>Domain2 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R/W | 0x0 | DM2_M0_WT_AUT_CTRL<br>Domain2 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | DM2_M0_RD_AUT_CTRL<br>Domain2 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.11.6.22. 0x00B8 IOMMU Domain Authority Control Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG2                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                 |
| 29             | R/W        | 0x0         | DM5_M6_WT_AUT_CTRL<br>Domain5 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM5_M6_RD_AUT_CTRL                                                                                                                                |

|    |     |     |                                                                                                                                                   |
|----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | Domain5 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                          |
| 27 | R/W | 0x0 | DM5_M5_WT_AUT_CTRL<br>Domain5 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26 | R/W | 0x0 | DM5_M5_RD_AUT_CTRL<br>Domain5 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25 | R/W | 0x0 | DM5_M4_WT_AUT_CTRL<br>Domain5 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24 | R/W | 0x0 | DM5_M4_RD_AUT_CTRL<br>Domain5 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23 | R/W | 0x0 | DM5_M3_WT_AUT_CTRL<br>Domain5 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22 | R/W | 0x0 | DM5_M3_RD_AUT_CTRL<br>Domain5 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21 | R/W | 0x0 | DM5_M2_WT_AUT_CTRL<br>Domain5 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20 | R/W | 0x0 | DM5_M2_RD_AUT_CTRL<br>Domain5 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19 | R/W | 0x0 | DM5_M1_WT_AUT_CTRL<br>Domain5 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18 | R/W | 0x0 | DM5_M1_RD_AUT_CTRL<br>Domain5 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17 | R/W | 0x0 | DM5_M0_WT_AUT_CTRL<br>Domain5 write permission control for master0                                                                                |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: The write-operation is permitted<br>1: The write-operation is prohibited                                                                       |
| 16    | R/W | 0x0 | DM5_M0_RD_AUT_CTRL<br>Domain5 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                 |
| 13    | R/W | 0x0 | DM4_M6_WT_AUT_CTRL<br>Domain4 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM4_M6_RD_AUT_CTRL<br>Domain4 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R/W | 0x0 | DM4_M5_WT_AUT_CTRL<br>Domain4 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R/W | 0x0 | DM4_M5_RD_AUT_CTRL<br>Domain4 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R/W | 0x0 | DM4_M4_WT_AUT_CTRL<br>Domain4 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8     | R/W | 0x0 | DM4_M4_RD_AUT_CTRL<br>Domain4 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7     | R/W | 0x0 | DM4_M3_WT_AUT_CTRL<br>Domain4 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6     | R/W | 0x0 | DM4_M3_RD_AUT_CTRL<br>Domain4 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5     | R/W | 0x0 | DM4_M2_WT_AUT_CTRL<br>Domain4 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4     | R/W | 0x0 | DM4_M2_RD_AUT_CTRL<br>Domain4 read permission control for master2                                                                                 |

|   |     |     |                                                                                                                                                   |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: The read-operation is permitted<br>1: The read-operation is prohibited                                                                         |
| 3 | R/W | 0x0 | DM4_M1_WT_AUT_CTRL<br>Domain4 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R/W | 0x0 | DM4_M1_RD_AUT_CTRL<br>Domain4 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R/W | 0x0 | DM4_M0_WT_AUT_CTRL<br>Domain4 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | DM4_M0_RD_AUT_CTRL<br>Domain4 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.11.6.23. 0x00BC IOMMU Domain Authority Control Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x00BC |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG3                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                 |
| 29             | R/W        | 0x0         | DM7_M6_WT_AUT_CTRL<br>Domain7 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM7_M6_RD_AUT_CTRL<br>Domain7 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM7_M5_WT_AUT_CTRL<br>Domain7 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM7_M5_RD_AUT_CTRL<br>Domain7 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM7_M4_WT_AUT_CTRL<br>Domain7 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | R/W | 0x0 | DM7_M4_RD_AUT_CTRL<br>Domain7 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23    | R/W | 0x0 | DM7_M3_WT_AUT_CTRL<br>Domain7 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22    | R/W | 0x0 | DM7_M3_RD_AUT_CTRL<br>Domain7 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21    | R/W | 0x0 | DM7_M2_WT_AUT_CTRL<br>Domain7 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20    | R/W | 0x0 | DM7_M2_RD_AUT_CTRL<br>Domain7 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM7_M1_WT_AUT_CTRL<br>Domain7 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM7_M1_RD_AUT_CTRL<br>Domain7 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM7_M0_WT_AUT_CTRL<br>Domain7 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM7_M0_RD_AUT_CTRL<br>Domain7 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                 |
| 13    | R/W | 0x0 | DM6_M6_WT_AUT_CTRL<br>Domain6 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM6_M6_RD_AUT_CTRL<br>Domain6 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

|    |     |     |                                                                                                                                                   |
|----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 11 | R/W | 0x0 | DM6_M5_WT_AUT_CTRL<br>Domain6 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10 | R/W | 0x0 | DM6_M5_RD_AUT_CTRL<br>Domain6 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9  | R/W | 0x0 | DM6_M4_WT_AUT_CTRL<br>Domain6 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8  | R/W | 0x0 | DM6_M4_RD_AUT_CTRL<br>Domain6 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7  | R/W | 0x0 | DM6_M3_WT_AUT_CTRL<br>Domain6 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6  | R/W | 0x0 | DM6_M3_RD_AUT_CTRL<br>Domain6 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5  | R/W | 0x0 | DM6_M2_WT_AUT_CTRL<br>Domain6 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4  | R/W | 0x0 | DM6_M2_RD_AUT_CTRL<br>Domain6 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3  | R/W | 0x0 | DM6_M1_WT_AUT_CTRL<br>Domain6 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2  | R/W | 0x0 | DM6_M1_RD_AUT_CTRL<br>Domain6 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1  | R/W | 0x0 | DM6_M0_WT_AUT_CTRL<br>Domain6 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0  | R/W | 0x0 | DM6_M0_RD_AUT_CTRL                                                                                                                                |

|  |  |  |                                                                                                                          |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------|
|  |  |  | Domain6 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------|

### 3.11.6.24. 0x00C0 IOMMU Domain Authority Control Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG4                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                 |
| 29             | R/W        | 0x0         | DM9_M6_WT_AUT_CTRL<br>Domain9 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM9_M6_RD_AUT_CTRL<br>Domain9 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM9_M5_WT_AUT_CTRL<br>Domain9 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM9_M5_RD_AUT_CTRL<br>Domain9 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM9_M4_WT_AUT_CTRL<br>Domain9 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24             | R/W        | 0x0         | DM9_M4_RD_AUT_CTRL<br>Domain9 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM9_M3_WT_AUT_CTRL<br>Domain9 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM9_M3_RD_AUT_CTRL<br>Domain9 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM9_M2_WT_AUT_CTRL<br>Domain9 write permission control for master2<br>0: The write-operation is permitted                                         |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: The write-operation is prohibited                                                                                                              |
| 20    | R/W | 0x0 | DM9_M2_RD_AUT_CTRL<br>Domain9 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM9_M1_WT_AUT_CTRL<br>Domain9 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM9_M1_RD_AUT_CTRL<br>Domain9 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM9_M0_WT_AUT_CTRL<br>Domain9 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM9_M0_RD_AUT_CTRL<br>Domain9 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                 |
| 13    | R/W | 0x0 | DM8_M6_WT_AUT_CTRL<br>Domain8 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM8_M6_RD_AUT_CTRL<br>Domain8 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R/W | 0x0 | DM8_M5_WT_AUT_CTRL<br>Domain8 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R/W | 0x0 | DM8_M5_RD_AUT_CTRL<br>Domain8 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R/W | 0x0 | DM8_M4_WT_AUT_CTRL<br>Domain8 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8     | R/W | 0x0 | DM8_M4_RD_AUT_CTRL<br>Domain8 read permission control for master4<br>0: The read-operation is permitted                                           |

|   |     |     |                                                                                                                                                   |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: The read-operation is prohibited                                                                                                               |
| 7 | R/W | 0x0 | DM8_M3_WT_AUT_CTRL<br>Domain8 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6 | R/W | 0x0 | DM8_M3_RD_AUT_CTRL<br>Domain8 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5 | R/W | 0x0 | DM8_M2_WT_AUT_CTRL<br>Domain8 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4 | R/W | 0x0 | DM8_M2_RD_AUT_CTRL<br>Domain8 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3 | R/W | 0x0 | DM8_M1_WT_AUT_CTRL<br>Domain8 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R/W | 0x0 | DM8_M1_RD_AUT_CTRL<br>Domain8 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R/W | 0x0 | DM8_M0_WT_AUT_CTRL<br>Domain8 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | DM8_M0_RD_AUT_CTRL<br>Domain8 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.11.6.25. 0x00C4 IOMMU Domain Authority Control Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG5                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                   |
| 29             | R/W        | 0x0         | DM11_M6_WT_AUT_CTRL<br>Domain11 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM11_M6_RD_AUT_CTRL                                                                                                                                 |

|    |     |     |                                                                                                                                                     |
|----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | Domain11 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                           |
| 27 | R/W | 0x0 | DM11_M5_WT_AUT_CTRL<br>Domain11 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26 | R/W | 0x0 | DM11_M5_RD_AUT_CTRL<br>Domain11 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25 | R/W | 0x0 | DM11_M4_WT_AUT_CTRL<br>Domain11 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24 | R/W | 0x0 | DM11_M4_RD_AUT_CTRL<br>Domain11 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23 | R/W | 0x0 | DM11_M3_WT_AUT_CTRL<br>Domain11 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22 | R/W | 0x0 | DM11_M3_RD_AUT_CTRL<br>Domain11 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21 | R/W | 0x0 | DM11_M2_WT_AUT_CTRL<br>Domain11 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20 | R/W | 0x0 | DM11_M2_RD_AUT_CTRL<br>Domain11 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19 | R/W | 0x0 | DM11_M1_WT_AUT_CTRL<br>Domain11 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18 | R/W | 0x0 | DM11_M1_RD_AUT_CTRL<br>Domain11 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17 | R/W | 0x0 | DM11_M0_WT_AUT_CTRL<br>Domain11 write permission control for master0                                                                                |

|       |     |     |                                                                                                                                                     |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: The write-operation is permitted<br>1: The write-operation is prohibited                                                                         |
| 16    | R/W | 0x0 | DM11_M0_RD_AUT_CTRL<br>Domain11 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                   |
| 13    | R/W | 0x0 | DM10_M6_WT_AUT_CTRL<br>Domain10 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM10_M6_RD_AUT_CTRL<br>Domain10 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R/W | 0x0 | DM10_M5_WT_AUT_CTRL<br>Domain10 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R/W | 0x0 | DM10_M5_RD_AUT_CTRL<br>Domain10 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R/W | 0x0 | DM10_M4_WT_AUT_CTRL<br>Domain10 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8     | R/W | 0x0 | DM10_M4_RD_AUT_CTRL<br>Domain10 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7     | R/W | 0x0 | DM10_M3_WT_AUT_CTRL<br>Domain10 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6     | R/W | 0x0 | DM10_M3_RD_AUT_CTRL<br>Domain10 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5     | R/W | 0x0 | DM10_M2_WT_AUT_CTRL<br>Domain10 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4     | R/W | 0x0 | DM10_M2_RD_AUT_CTRL<br>Domain10 read permission control for master2                                                                                 |

|   |     |     |                                                                                                                                                     |
|---|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: The read-operation is permitted<br>1: The read-operation is prohibited                                                                           |
| 3 | R/W | 0x0 | DM10_M1_WT_AUT_CTRL<br>Domain10 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R/W | 0x0 | DM10_M1_RD_AUT_CTRL<br>Domain10 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R/W | 0x0 | DM10_M0_WT_AUT_CTRL<br>Domain10 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | DM10_M0_RD_AUT_CTRL<br>Domain10 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.11.6.26. 0x00C8 IOMMU Domain Authority Control Register 6 (Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG6                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                   |
| 29             | R/W        | 0x0         | DM13_M6_WT_AUT_CTRL<br>Domain13 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM13_M6_RD_AUT_CTRL<br>Domain13 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM13_M5_WT_AUT_CTRL<br>Domain13 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM13_M5_RD_AUT_CTRL<br>Domain13 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM13_M4_WT_AUT_CTRL<br>Domain13 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |

|       |     |     |                                                                                                                                                     |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | R/W | 0x0 | DM13_M4_RD_AUT_CTRL<br>Domain13 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23    | R/W | 0x0 | DM13_M3_WT_AUT_CTRL<br>Domain13 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22    | R/W | 0x0 | DM13_M3_RD_AUT_CTRL<br>Domain13 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21    | R/W | 0x0 | DM13_M2_WT_AUT_CTRL<br>Domain13 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20    | R/W | 0x0 | DM13_M2_RD_AUT_CTRL<br>Domain13 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM13_M1_WT_AUT_CTRL<br>Domain13 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM13_M1_RD_AUT_CTRL<br>Domain13 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM13_M0_WT_AUT_CTRL<br>Domain13 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM13_M0_RD_AUT_CTRL<br>Domain13 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                   |
| 13    | R/W | 0x0 | DM12_M6_WT_AUT_CTRL<br>Domain12 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM12_M6_RD_AUT_CTRL<br>Domain12 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

|    |     |     |                                                                                                                                                     |
|----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 11 | R/W | 0x0 | DM12_M5_WT_AUT_CTRL<br>Domain12 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10 | R/W | 0x0 | DM12_M5_RD_AUT_CTRL<br>Domain12 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9  | R/W | 0x0 | DM12_M4_WT_AUT_CTRL<br>Domain12 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8  | R/W | 0x0 | DM12_M4_RD_AUT_CTRL<br>Domain12 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7  | R/W | 0x0 | DM12_M3_WT_AUT_CTRL<br>Domain12 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6  | R/W | 0x0 | DM12_M3_RD_AUT_CTRL<br>Domain12 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5  | R/W | 0x0 | DM12_M2_WT_AUT_CTRL<br>Domain12 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4  | R/W | 0x0 | DM12_M2_RD_AUT_CTRL<br>Domain12 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3  | R/W | 0x0 | DM12_M1_WT_AUT_CTRL<br>Domain12 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2  | R/W | 0x0 | DM12_M1_RD_AUT_CTRL<br>Domain12 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1  | R/W | 0x0 | DM12_M0_WT_AUT_CTRL<br>Domain12 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0  | R/W | 0x0 | DM12_M0_RD_AUT_CTRL                                                                                                                                 |

|  |  |  |                                                                                                                           |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------|
|  |  |  | Domain12 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------|

### 3.11.6.27. 0x00CC IOMMU Domain Authority Control Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL_REG7                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                   |
| 29             | R/W        | 0x0         | DM15_M6_WT_AUT_CTRL<br>Domain15 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM15_M6_RD_AUT_CTRL<br>Domain15 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM15_M5_WT_AUT_CTRL<br>Domain15 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM15_M5_RD_AUT_CTRL<br>Domain15 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM15_M4_WT_AUT_CTRL<br>Domain15 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24             | R/W        | 0x0         | DM15_M4_RD_AUT_CTRL<br>Domain15 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM15_M3_WT_AUT_CTRL<br>Domain15 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM15_M3_RD_AUT_CTRL<br>Domain15 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM15_M2_WT_AUT_CTRL<br>Domain15 write permission control for master2<br>0: The write-operation is permitted                                         |

|       |     |     |                                                                                                                                                     |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: The write-operation is prohibited                                                                                                                |
| 20    | R/W | 0x0 | DM15_M2_RD_AUT_CTRL<br>Domain15 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19    | R/W | 0x0 | DM15_M1_WT_AUT_CTRL<br>Domain15 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18    | R/W | 0x0 | DM15_M1_RD_AUT_CTRL<br>Domain15 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17    | R/W | 0x0 | DM15_M0_WT_AUT_CTRL<br>Domain15 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16    | R/W | 0x0 | DM15_M0_RD_AUT_CTRL<br>Domain15 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14 | /   | /   | /                                                                                                                                                   |
| 13    | R/W | 0x0 | DM14_M6_WT_AUT_CTRL<br>Domain14 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12    | R/W | 0x0 | DM14_M6_RD_AUT_CTRL<br>Domain14 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11    | R/W | 0x0 | DM14_M5_WT_AUT_CTRL<br>Domain14 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10    | R/W | 0x0 | DM14_M5_RD_AUT_CTRL<br>Domain14 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9     | R/W | 0x0 | DM14_M4_WT_AUT_CTRL<br>Domain14 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8     | R/W | 0x0 | DM14_M4_RD_AUT_CTRL<br>Domain14 read permission control for master4<br>0: The read-operation is permitted                                           |

|   |     |     |                                                                                                                                                     |
|---|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: The read-operation is prohibited                                                                                                                 |
| 7 | R/W | 0x0 | DM14_M3_WT_AUT_CTRL<br>Domain14 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6 | R/W | 0x0 | DM14_M3_RD_AUT_CTRL<br>Domain14 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5 | R/W | 0x0 | DM14_M2_WT_AUT_CTRL<br>Domain14 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4 | R/W | 0x0 | DM14_M2_RD_AUT_CTRL<br>Domain14 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3 | R/W | 0x0 | DM14_M1_WT_AUT_CTRL<br>Domain14 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2 | R/W | 0x0 | DM14_M1_RD_AUT_CTRL<br>Domain14 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1 | R/W | 0x0 | DM14_M0_WT_AUT_CTRL<br>Domain14 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | DM14_M0_RD_AUT_CTRL<br>Domain14 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.11.6.28. 0x00D0 IOMMU Domain Authority Overwrite Register (Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: IOMMU_DM_AUT_OVWT_REG                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31             | R/W        | 0x0         | DM_AUT_OVWT_ENABLE<br>Domain write/read permission overwrite enable<br>0: Disable<br>1: Enable |
| 30:14          | /          | /           | /                                                                                              |
| 13             | R/W        | 0x0         | M6_WT_AUT_OVWT_CTRL                                                                            |

|    |     |     |                                                                                                                                                  |
|----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | Master6 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                        |
| 12 | R/W | 0x0 | M6_RD_AUT_OVWT_CTRL<br>Master6 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11 | R/W | 0x0 | M5_WT_AUT_OVWT_CTRL<br>Master5 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10 | R/W | 0x0 | M5_RD_AUT_OVWT_CTRL<br>Master5 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9  | R/W | 0x0 | M4_WT_AUT_OVWT_CTRL<br>Master5 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8  | R/W | 0x0 | M4_RD_AUT_OVWT_CTRL<br>Master5 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7  | R/W | 0x0 | M3_WT_AUT_OVWT_CTRL<br>Master3 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6  | R/W | 0x0 | M3_RD_AUT_OVWT_CTRL<br>Master3 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5  | R/W | 0x0 | M2_WT_AUT_OVWT_CTRL<br>Master2 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4  | R/W | 0x0 | M2_RD_AUT_OVWT_CTRL<br>Master2 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3  | R/W | 0x0 | M1_WT_AUT_OVWT_CTRL<br>Master1 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2  | R/W | 0x0 | M1_RD_AUT_OVWT_CTRL<br>Master1 read permission overwrite control                                                                                 |

|   |     |     |                                                                                                                                                  |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: The read-operation is permitted<br>1: The read-operation is prohibited                                                                        |
| 1 | R/W | 0x0 | M0_WT_AUT_OVWT_CTRL<br>Master0 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0 | R/W | 0x0 | M0_RD_AUT_OVWT_CTRL<br>Master0 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |


**NOTE**

Setting the REG\_ARD\_OVWT can mask the Domain control defined by IOMMU\_DM\_AUT\_CTRL\_REG0~7. All the property of Level2 are covered by the property defined in REG\_ARD\_OVWT. Allow read and write for all by default.

### 3.11.6.29. 0x0100 IOMMU Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: IOMMU_INT_ENABLE_REG                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31:18          | /          | /           | /                                                                                                                   |
| 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 |
| 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                        |

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

**NOTE**

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

### 3.11.6.30. 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<br>0: Invalid operation<br>1: Clear interrupt |
| 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                                                                                                    |

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

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

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

### 3.11.6.32. 0x0110 IOMMU Interrupt Error Address Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG0                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR0<br>Virtual address that caused Micro TLB0 to interrupt |

### 3.11.6.33. 0x0114 IOMMU Interrupt Error Address Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG1                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR1<br>Virtual address that caused Micro TLB1 to interrupt |

### 3.11.6.34. 0x0118 IOMMU Interrupt Error Address Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0118 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG2                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR2<br>Virtual address that caused Micro TLB2 to interrupt |

**3.11.6.35. 0x011C IOMMU Interrupt Error Address Register 3 (Default Value: 0x0000\_0000)**

| Offset: 0x011C |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG3                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR3<br>Virtual address that caused Micro TLB3 to interrupt |

**3.11.6.36. 0x0120 IOMMU Interrupt Error Address Register 4 (Default Value: 0x0000\_0000)**

| Offset: 0x0120 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG4                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR4<br>Virtual address that caused Micro TLB4 to interrupt |

**3.11.6.37. 0x0124 IOMMU Interrupt Error Address Register 5 (Default Value: 0x0000\_0000)**

| Offset: 0x0124 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG5                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR5<br>Virtual address that caused Micro TLB5 to interrupt |

**3.11.6.38. 0x0128 IOMMU Interrupt Error Address Register 6 (Default Value: 0x0000\_0000)**

| Offset: 0x0128 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG6                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR6<br>Virtual address that caused Micro TLB6 to interrupt |

**3.11.6.39. 0x0130 IOMMU Interrupt Error Address Register 7 (Default Value: 0x0000\_0000)**

| Offset: 0x0130 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG7                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:0           | R          | 0x0         | INT_ERR_ADDR7<br>Virtual address that caused L1 page table to interrupt |

**3.11.6.40. 0x0134 IOMMU Interrupt Error Address Register 8 (Default Value: 0x0000\_0000)**

| Offset: 0x0134 |            |             | Register Name: IOMMU_INT_ERR_ADDR_REG8 |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |

|      |   |     |                                                                         |
|------|---|-----|-------------------------------------------------------------------------|
| 31:0 | R | 0x0 | INT_ERR_ADDR8<br>Virtual address that caused L2 page table to interrupt |
|------|---|-----|-------------------------------------------------------------------------|

#### 3.11.6.41. 0x0150 IOMMU Interrupt Error Data Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0150 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG0                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA0<br>Corresponding page table of virtual address that caused Micro TLB0 to interrupt |

#### 3.11.6.42. 0x0154 IOMMU Interrupt Error Data Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0154 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG1                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA1<br>Corresponding page table of virtual address that caused Micro TLB1 to interrupt |

#### 3.11.6.43. 0x0158 IOMMU Interrupt Error Data Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0158 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG2                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA2<br>Corresponding page table of virtual address that caused Micro TLB2 to interrupt |

#### 3.11.6.44. 0x015C IOMMU Interrupt Error Data Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x015C |            |             | Register Name: IOMMU_INT_ERR_DATA_REG3                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA3<br>Corresponding page table of virtual address that caused Micro TLB3 to interrupt |

#### 3.11.6.45. 0x0160 IOMMU Interrupt Error Data Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG4 |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |

|      |   |     |                                                                                                  |
|------|---|-----|--------------------------------------------------------------------------------------------------|
| 31:0 | R | 0x0 | INT_ERR_DATA4<br>Corresponding page table of virtual address that caused Micro TLB4 to interrupt |
|------|---|-----|--------------------------------------------------------------------------------------------------|

#### 3.11.6.46. 0x0164 IOMMU Interrupt Error Data Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0164 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG5                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA5<br>Corresponding page table of virtual address that caused Micro TLB5 to interrupt |

#### 3.11.6.47. 0x0168 IOMMU Interrupt Error Data Register 6 (Default Value: 0x0000\_0000)

| Offset: 0x0168 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG6                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA6<br>Corresponding page table of virtual address that caused Micro TLB6 to interrupt |

#### 3.11.6.48. 0x0170 IOMMU Interrupt Error Data Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x0170 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG7                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:0           | R          | 0x0         | INT_ERR_DATA7<br>Corresponding page table of virtual address that caused L1 page table to interrupt |

#### 3.11.6.49. 0x0174 IOMMU Interrupt Error Data Register 8 (Default Value: 0x0000\_0000)

| Offset: 0x0174 |            |             | Register Name: IOMMU_INT_ERR_DATA_REG8                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:0           | R          | 0x0         | INT_ERR_DATA8<br>Corresponding page table of virtual address that caused L2 page table to interrupt |

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

### 3.11.6.51. 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.     |
| 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.     |
| 0              | R          | 0x0         | MASTER0_L2PG_INT<br>Master0 address switch causes L2 page table to occur interrupt.     |

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

### 3.11.6.53. 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 of read/write virtual address |

### 3.11.6.54. 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><br>It is used to chose prefetch mode or Debug mode.                                                  |
| 31:9           | /          | /           | /                                                                                                                                                 |
| 8              | R/W        | 0x0         | VA_CONFIG<br>0: Read operation<br>1: Write operation                                                                                              |
| 7:1            | /          | /           | /                                                                                                                                                 |
| 0              | R/WAC      | 0x0         | VA_CONFIG_START<br>0: No operation or operation completes<br>1: Start<br><br>After the operation completes, the bit can clear to 0 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;

e) Query IOMMU\_VA\_CONFIG\_REG[0] until it is 0;

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

### 3.11.6.56. 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 completes<br>1: Clear counter data<br>After the operation completes, the bit can clear to 0 automatically. |

### 3.11.6.57. 0x0230 IOMMU PMU Access Low Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG0                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.58. 0x0234 IOMMU PMU Access High Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG0                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH0<br>Record total number of Micro TLB0 access , higher 11-bit register |

### 3.11.6.59. 0x0238 IOMMU PMU Hit Low Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0238 | Register Name: IOMMU_PMU_HIT_LOW_REG0 |
|----------------|---------------------------------------|
|----------------|---------------------------------------|

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

### 3.11.6.60. 0x023C IOMMU PMU Hit High Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x023C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG0                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH0<br>Record total number of Micro TLB0 hit , higher 11-bit register |

### 3.11.6.61. 0x0240 IOMMU PMU Access Low Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG1                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.62. 0x0244 IOMMU PMU Access High Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0244 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG1                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:11          | /          | /           | /                                                                                     |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH1<br>Record total number of Micro TLB1 access , higher 11-bit register |

### 3.11.6.63. 0x0248 IOMMU PMU Hit Low Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG1                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| 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 |

### 3.11.6.64. 0x024C IOMMU PMU Hit High Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x024C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG1 |
|----------------|------------|-------------|----------------------------------------|
| 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 |
|------|---|-----|---------------------------------------------------------------------------------|

**3.11.6.65. 0x0250 IOMMU PMU Access Low Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x0250 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG2                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| 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 |

**3.11.6.66. 0x0254 IOMMU PMU Access High Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x0254 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG2                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| 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 |

**3.11.6.67. 0x0258 IOMMU PMU Hit Low Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x0258 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG2                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| 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 |

**3.11.6.68. 0x025C IOMMU PMU Hit High Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x025C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG2                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| 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 |

**3.11.6.69. 0x0260 IOMMU PMU Access Low Register 3 (Default Value: 0x0000\_0000)**

| Offset: 0x0260 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG3                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| 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 |

**3.11.6.70. 0x0264 IOMMU PMU Access High Register 3 (Default Value: 0x0000\_0000)**

| Offset: 0x0264 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG3                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| 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 |

**3.11.6.71. 0x0268 IOMMU PMU Hit Low Register 3 (Default Value: 0x0000\_0000)**

| Offset: 0x0268 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG3                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| 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 |

**3.11.6.72. 0x026C IOMMU PMU Hit High Register 3 (Default Value: 0x0000\_0000)**

| Offset: 0x026C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG3                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| 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 |

**3.11.6.73. 0x0270 IOMMU PMU Access Low Register 4 (Default Value: 0x0000\_0000)**

| Offset: 0x0270 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG4                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| 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 |

**3.11.6.74. 0x0274 IOMMU PMU Access High Register 4 (Default Value: 0x0000\_0000)**

| Offset: 0x0274 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG4                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.75. 0x0278 IOMMU PMU Hit Low Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG4                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| 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 |

### 3.11.6.76. 0x027C IOMMU PMU Hit High Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x027C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG4                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| 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 |

### 3.11.6.77. 0x0280 IOMMU PMU Access Low Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0280 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG5                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.78. 0x0284 IOMMU PMU Access High Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0284 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG5                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.79. 0x0288 IOMMU PMU Hit Low Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0288 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG5                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| 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 |

### 3.11.6.80. 0x028C IOMMU PMU Hit High Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x028C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG5                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| 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 |

### 3.11.6.81. 0x0290 IOMMU PMU Access Low Register6 (Default Value: 0x0000\_0000)

| Offset: 0x0290 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG6                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.82. 0x0294 IOMMU PMU Access High Register 6 (Default Value: 0x0000\_0000)

| Offset: 0x0294 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG6                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.83. 0x0298 IOMMU PMU Hit Low Register 6 (Default Value: 0x0000\_0000)

| Offset: 0x0298 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG6                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| 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 |

### 3.11.6.84. 0x029C IOMMU PMU Hit High Register 6 (Default Value: 0x0000\_0000)

| Offset: 0x029C |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG6                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| 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 |

### 3.11.6.85. 0x02D0 IOMMU PMU Access Low Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x02D0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG7                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW7<br>Record total number of Micro TLB7 access, lower 32-bit register |

### 3.11.6.86. 0x02D4 IOMMU PMU Access High Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x02D4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG7                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH7<br>Record total number of Micro TLB7 access, higher 11-bit register |

### 3.11.6.87. 0x02D8 IOMMU PMU Hit Low Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x02D8 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG7                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW7<br>Record total number of Micro TLB7 hit, lower 32-bit register |

### 3.11.6.88. 0x02DC IOMMU PMU Hit High Register 7 (Default Value: 0x0000\_0000)

| Offset: 0x02DC |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG7                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH7<br>Record total number of Micro TLB7 hit, higher 11-bit register |

### 3.11.6.89. 0x02E0 IOMMU PMU Access Low Register 8 (Default Value: 0x0000\_0000)

| Offset: 0x02E0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW_REG8                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| 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 |

### 3.11.6.90. 0x02E4 IOMMU PMU Access High Register 8 (Default Value: 0x0000\_0000)

| Offset: 0x02E4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH_REG8                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| 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 |

### 3.11.6.91. 0x02E8 IOMMU PMU Hit Low Register 8 (Default Value: 0x0000\_0000)

| Offset: 0x02E8 |            |             | Register Name: IOMMU_PMU_HIT_LOW_REG8                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| 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 |

### 3.11.6.92. 0x02EC IOMMU PMU Hit High Register 8 (Default Value: 0x0000\_0000)

| Offset: 0x02EC |            |             | Register Name: IOMMU_PMU_HIT_HIGH_REG8                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| 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 |

### 3.11.6.93. 0x0300 IOMMU Total Latency Low Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG0                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW0<br>Record total latency of Master0, lower 32-bit register |

### 3.11.6.94. 0x0304 IOMMU Total Latency High Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0304 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG0                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

**3.11.6.95. 0x0308 IOMMU Max Latency Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x0308 |            |             | Register Name: IOMMU_PMU_ML_REG0              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML0<br>Record the max latency of Master0. |

**3.11.6.96. 0x0310 IOMMU Total Latency Low Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0310 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG1                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW1<br>Record total latency of Master1, lower 32-bit register |

**3.11.6.97. 0x0314 IOMMU Total Latency High Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0314 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG1                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

**3.11.6.98. 0x0318 IOMMU Max Latency Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0318 |            |             | Register Name: IOMMU_PMU_ML_REG1              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML1<br>Record the max latency of Master1. |

**3.11.6.99. 0x0320 IOMMU Total Latency Low Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x0320 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG2                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW2<br>Record total latency of Master2, lower 32-bit register |

**3.11.6.100. 0x0324 IOMMU Total Latency High Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x0324 |  | Register Name: IOMMU_PMU_TL_HIGH_REG2 |
|----------------|--|---------------------------------------|
|                |  |                                       |

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

### 3.11.6.101. 0x0328 IOMMU Max Latency Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0328 |            |             | Register Name: IOMMU_PMU_ML_REG2              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML2<br>Record the max latency of Master2. |

### 3.11.6.102. 0x0330 IOMMU Total Latency Low Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x0330 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG3                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW3<br>Record total latency of Master3, lower 32-bit register |

### 3.11.6.103. 0x0334 IOMMU Total Latency High Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG3                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

### 3.11.6.104. 0x0338 IOMMU Max Latency Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x0338 |            |             | Register Name: IOMMU_PMU_ML_REG3              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML3<br>Record the max latency of Master3. |

### 3.11.6.105. 0x0340 IOMMU Total Latency Low Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG4 |
|----------------|------------|-------------|--------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                          |
| 31:0           | R          | 0x0         | PMU_TL_LOW4                          |

|  |  |  |                                                        |
|--|--|--|--------------------------------------------------------|
|  |  |  | Record total latency of Master4, lower 32-bit register |
|--|--|--|--------------------------------------------------------|

### 3.11.6.106. 0x0344 IOMMU Total Latency High Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG4                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

### 3.11.6.107. 0x0348 IOMMU Max Latency Register 4 (Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: IOMMU_PMU_ML_REG4              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML4<br>Record the max latency of Master4. |

### 3.11.6.108. 0x0350 IOMMU Total Latency Low Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0350 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG5                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW5<br>Record total latency of Master5, lower 32-bit register |

### 3.11.6.109. 0x0354 IOMMU Total Latency High Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0354 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG5                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

### 3.11.6.110. 0x0358 IOMMU Max Latency Register 5 (Default Value: 0x0000\_0000)

| Offset: 0x0358 |            |             | Register Name: IOMMU_PMU_ML_REG5              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML5<br>Record the max latency of Master5. |

**3.11.6.111. 0x0360 IOMMU Total Latency Low Register 6 (Default Value: 0x0000\_0000)**

| Offset: 0x0360 |            |             | Register Name: IOMMU_PMU_TL_LOW_REG6                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW6<br>Record total latency of Master6, lower 32-bit register |

**3.11.6.112. 0x0364 IOMMU Total Latency High Register 6 (Default Value: 0x0000\_0000)**

| Offset: 0x0364 |            |             | Register Name: IOMMU_PMU_TL_HIGH_REG6                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| 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 |

**3.11.6.113. 0x0368 IOMMU Max Latency Register 6 (Default Value: 0x0000\_0000)**

| Offset: 0x0368 |            |             | Register Name: IOMMU_PMU_ML_REG6              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML6<br>Record the max latency of Master6. |

## 3.12. RTC

### 3.12.1. Overview

The RTC(Real Time Clock) is used to implement time counter and 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
- External connect a 32.768 kHz low-frequency oscillator for count clock
- Timer frequency is 1 kHz
- Configurable initial value by software anytime
- Supports timing alarm, and generates interrupt and wakeup the external devices
- Supports 32.768 kHz calibration function divided by RC16M, and power-off wakeup calibration
- Supports fanout function of internal 32K clock
- 8 general purpose registers for storing power-off information

### 3.12.2. Clock Tree Diagram

The clock tree diagram of RTC is shown in Figure 3-31.



Figure 3- 31. RTC Clock Tree

RTC clock tree can be selected by corresponding switch, there are 3 options: RC16M, LOSC from crystal, 32K clock after calibrated.

Clock source: 32.768 kHz low-frequency crystal, the division clock of 16 MHz RC oscillator(uncalibrated), and the division clock after 16 MHz RC calibrated.

Output clock: CLK32K and RTC\_32K\_FANOUT.

### 3.12.3. Operations and Functional Descriptions

#### 3.12.3.1. External Signals

Table 3- 12. RTC External Signals

| Signal  | Description                                                                  |
|---------|------------------------------------------------------------------------------|
| X32KIN  | 32.768 kHz oscillator input                                                  |
| X32KOUT | 32.768 kHz oscillator output                                                 |
| 32KFOUT | 32.768 kHz clock fanout<br>Provides low frequency clock for external devices |
| NMI     | Alarm wakeup generates low level into NMI                                    |
| RTC_VIO | RTC low voltage, generated via internal LDO                                  |
| VCC_RTC | RTC high voltage, generated via external power                               |

#### 3.12.3.2. Clock and Reset

The RTC module has the independent reset signal, the signal follows VCC\_RTC. When VCC\_RTC powers on, the reset signal resets the RTC module; after VCC\_RTC reaches stable, the reset signal always holds high level. Watchdog Reset cannot reset RTC.

The RTC module accesses its register by AHBS1.

### 3.12.3.3. Typical Application



**Figure 3- 32. RTC Application Diagram**

The external low-frequency oscillator must be 32.768 kHz. If the external peripheral needs low frequency crystal, which can be provided by X32KFOUT.

AP-NMI# and alarm0 in common generate low level signal.

### 3.12.3.4. Function Implementation

#### 3.12.3.4.1. Clock Sources

The RTC has 2 clock sources: internal RC, external low frequency crystal.

The RTC selects the internal RC by default, when the system starts, the RTC can select by software the external low frequency crystal to provide much accuracy clock. The clock accurate of the RTC is related to the accurate of the external low frequency crystal. Usually select 32.768 kHz crystal with  $\pm 20$  ppm frequency tolerance.

When using internal RC, the clock of RTC can be changed by changing division ratio. When using external clock, the clock cannot be changed.

### 3.12.3.4.2. Real Time Clock



**Figure 3- 33. RTC Counter**

The 1K counter adds 1 on each rising edge of the clock. When the clock number reaches 0x3FF, 1K counter starts to count again from 0, and the second counter adds 1. The step structure of 1KHz counter is as follows.



**Figure 3- 34. RTC 1KHz Counter Step Structure**

According to above implementation, the changing range of each counter is as follows.

**Table 3- 13. RTC Counter Changing Range**

| Counter | Range                                                                                   |
|---------|-----------------------------------------------------------------------------------------|
| Second  | 0~59                                                                                    |
| Minute  | 0~59                                                                                    |
| Hour    | 0~23                                                                                    |
| Day     | 0~65535 (The year, month, day need be transformed by software according to day counter) |



Because there is no error correction mechanism in the hardware, note that each counter configuration should not exceed a reasonable counting range.

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

### 3.12.3.4.4. Power-off Storage

The RTC provides eight 32-bit general purpose register to store power-off information.

Because VCC-RTC always holds non-power-off state after VCC-RTC cold starts, when the system is in shutdown or standby scene, CPU can judge software process by the storing information.

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

### 3.12.3.4.6. RC Calibration

The basic circuit of RC calibration is shown in Figure 3-35. Whether to output the calibrated RC clock can be selected by the RC\_Cali\_SEL control bit, the calibration principle is as follows.

As shown in Figure 3-36, with OSC24M(24 MHz) 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. By dividing the accurate frequency by 32.768 kHz, the frequency divider(K) from RC clock to 32.768 kHz is obtained. Lastly, RC16M is divided into 32.768 kHz frequency by the frequency divider(K).



#### NOTE

The calibration principle is output 32.768 kHz, not input 16 MHz.



Figure 3- 35. Calibration Circuit



Figure 3- 36. RC Waveform

### 3.12.3.4.7. DCXO Timed Wakeup

The logic of DCXO timed wakeup circuit is relatively simple, including 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 Figure 3-37.



**Figure 3- 37. 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 us.

### 3.12.3.5. Operating Mode

#### 3.12.3.5.1. RTC Clock Control

- (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.
- (2) Auto switch: After enabled the bit[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**.
- (3) After auto switch is valid, the clock source status bit cannot be changed, because the two functions are independent.

### 3.12.3.5.2. RTC Calendar

- (1) Write time initial value: Write the current time to **RTC\_DAY\_REG** and **RTC\_HH\_MM\_SS\_REG**.
- (2) After configured time, read the bit[8:7] of **LOSC\_CTRL\_REG** to ensure that configuration is completed.
- (3) After update 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.

After configured time at each time, you need ensure the bit[8:7] of **LOSC\_CTRL\_REG** is 0 before the next setting is performed.

### 3.12.3.5.3. Alarm0

- (1) Enable alarm0 interrupt by writing **ALARM0\_IRQ\_EN**.
- (2) Set the counter comparator, write the count-down day, hour, minute, second number to **ALARM0\_DAY\_REG** and **ALARM0\_HH\_MM\_SS\_REG**.
- (3) Enable alarm0 function by writing **ALARM0\_ENABLE\_REG**, then the software can query alarm count value in real time by **ALARM0\_DAY\_REG** and **ALARM0\_HH\_MM\_SS\_REG**. When the setting time reaches, **ALARM0\_IRQ\_STA\_REG** is set to 1 to generate interrupt.
- (4) After enter the interrupt process, write **ALARM0\_IRQ\_STA\_REG** to clear the interrupt pending, and execute the interrupt process.
- (5) Resume the interrupt and continue to execute the interrupted process.
- (6) Power-off wakeup is generated via SoC hardware and PMIC, the software only need set pending condition of alarm0, and set 1 to **ALARM0\_CONFIG\_REG**.

### 3.12.3.5.4. Fanout

Set the bit0 of **LOSC\_OUT\_GATING\_REG** to 1, and ensure external pull-up resistor, voltage, clock source are normal, then 32.768kHz square wave can be output.

### 3.12.3.5.5. DRAM Data Encrypt

If using DRAM data encrypt, the DRAM data read by CPU is the encrypted data. The steps are as follows.

Before write/read **CRY\_KEY\_REG** and **CRY\_EN\_REG**, the bit[15:0] of **CRY\_CONFIG\_REG** should be written to 0x1689.



#### CAUTION

Before read/write each time, the step is needed to be performed, or else the register operation is no successful.

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

## 3.12.4. Programming Guidelines

### 3.12.4.1. RTC Clock Sources Setting

Configure **LOSC\_CTRL\_REG** to set RTC clock source.

For example: select external 32K clock source as RTC clock.

```
writel(0x16aa4000,LOSC_CTRL);      //write key field  
writel(0x16aa4001,LOSC_CTRL);      //select external 32K clock
```

### 3.12.4.2. Real Time Clock

For example: set time- 21', 07:08:09

```
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);
```

### 3.12.4.3. Alarm 0

```
irq_request(GIC_SRC_R_Alarm0, Alm0_handler);  
irq_enable(GIC_SRC_R_Alarm0);  
writel(1, ALARMO_DAY_SET_REG);  
writel(1, RTC_HH_MM_SS_REG);      //Set 1 second corresponding to normal mode;  
writel(1, ALM0_EN);  
writel(1, ALM_CONFIG);           //NMI output  
while(!readl(ALM0_IRQ_STA));  
writel(1, ALM0_IRQ_EN);  
while(readl(ALM0_IRQ_STA));
```

## 3.12.5. Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|     |            |
|-----|------------|
| RTC | 0x07000000 |
|-----|------------|

| Register Name            | Offset          | Description                                      |
|--------------------------|-----------------|--------------------------------------------------|
| LOSC_CTRL_REG            | 0x0000          | Low Oscillator 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_REG         | 0x0014          | RTC Hour-Minute-Second Register                  |
| ALARMO_COUNTER_REG       | 0x0020          | Alarm 0 Counter Register                         |
| ALARMO_CUR_VLU_REG       | 0x0024          | Alarm 0 Counter Current Value Register           |
| ALARMO_ENABLE_REG        | 0x0028          | Alarm 0 Enable Register                          |
| ALARMO_IRQ_EN            | 0x002C          | Alarm 0 IRQ Enable Register                      |
| ALARMO_IRQ_STA_REG       | 0x0030          | Alarm 0 IRQ Status Register                      |
| ALARM_CONFIG_REG         | 0x0050          | Alarm Configuration Register                     |
| LOSC_OUT_GATING_REG      | 0x0060          | LOSC Output Gating Register                      |
| GP_DATA_REG              | 0x0100 + N*0x04 | General Purpose Register (N=0~7)                 |
| FBOOT_INFO_REG0          | 0x0120          | Fast Boot Information Register0                  |
| FBOOT_INFO_REG1          | 0x0124          | Fast Boot Information Register1                  |
| DCXO_CTRL_REG            | 0x0160          | DCXO Control Register                            |
| CALI_CTRL_REG            | 0x0164          | Calibration Control Register                     |
| RTC_VIO_REG              | 0x0190          | RTC_VIO Regulate Register                        |
| IC_CHARA_REG             | 0x01F0          | IC Characteristic Register                       |
| EFUSE_HV_PWRSWT_CTRL_REG | 0x0204          | Efuse High Voltage Power Switch Control Register |
| RTC_SPI_CLK_CTRL_REG     | 0x0310          | RTC SPI Clock Control Register                   |

### 3.12.6. Register Description



The register configuration of RTC is AHB bus, it only can support word operation, not byte and half word operation.

#### 3.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 bit0 and bit1 can be |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | written with the new value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15   | R/W | 0x0 | <b>LOSC_AUTO_SWT_FUNCTION</b><br>LOSC auto switch function disable<br>0: Enable<br>1: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14   | R/W | 0x1 | <b>LOSC_AUTO_SWT_32K_SEL_EN</b><br>LOSC auto switch 32K clk source sel enable<br>0: Disable, when losc lost, 32k clk source will not change to RC<br>1: Enable, when losc lost, 32k clk source will change to RC(LOSC_SRC_SEL will be changed from 1 to 0)                                                                                                                                                                                                                                                                                                                                                              |
| 13:9 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 8    | R/W | 0x0 | <b>RTC_HHMMSS_ACCE</b><br>RTC HH-MM-SS 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 RTC HH-MM-SS Register will be refreshed for at most one second.                                                                                                                                                                                                                                                                                                                          |
| 7    | R/W | 0x0 | <b>RTC_DAY_ACCE</b><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.                                                                                                                                                                                                                                                                                                                                                     |
| 6:5  | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4    | R/W | 0x1 | <b>EXT_LOSC_EN</b><br>External 32.768 kHz Crystal Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:2  | R/W | 0x0 | <b>EXT_LOSC_GSM</b><br>External 32.768 kHz Crystal GSM<br>00: Low<br>01: /<br>10: /<br>11: High<br>When GSM is changed, 32K oscillation circuit will arise transient instability. If the auto switch function(bit 15) is enabled, 32K changes to RC16M with certain probability. 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.<br>If modifying GSM is necessary, firstly disable the auto switch function(bit 15), with a delay of 50us, then change GSM, 32K clock source is changed to external clock. |
| 1    | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | R/W | 0x0 | <b>LOSC_SRC_SEL</b><br>LOSC Clock source Select. 'N' is the value of Internal OSC Clock Prescalar                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

|  |  |  |                                                                              |
|--|--|--|------------------------------------------------------------------------------|
|  |  |  | Register.<br>0: Low Frequency Clock from 16M RC<br>1: External 32.768kHz OSC |
|--|--|--|------------------------------------------------------------------------------|


**NOTE**

If the bit[8:7] of LOSC\_CTRL\_REG is set, the RTC HH-MM-SS, DD and ALARM DD-HH-MM-SS register cannot be written.

### 3.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         | EXT_LOSC_STA<br>Work only when AUTO SWITCH function is enabled.<br>0: External 32.768 kHz OSC work normally<br>1: External 32.768 kHz OSC work abnormally                             |
| 1             | R/W1C      | 0x0         | LOSC_AUTO_SWT_PEND<br>LOSC auto switch pending<br>0: No effect<br>1: Auto switch pending, it means LOSC_SRC_SEL is changed from 1 to 0.<br>Setting 1 to this bit will clear it.       |
| 0             | R          | 0x0         | LOSC_SRC_SEL_STA<br>Checking LOSC Clock Source Status. '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 |

### 3.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         | INTOSC_32K_CLK_PRESCAL<br>Internal OSC 32K Clock Prescalar value N.<br>The clock output = Internal RC/32/N.<br>00000: 1<br>00001: 2<br>00002: 3<br>.....<br>11111: 32 |

### 3.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         | RO         | 0x1e8       | 32k calibration integer divider factor                                                                                           |
| 21:5          | RO         | 0x0         | 32k calibration decimal divider factor                                                                                           |
| 4             | R/W        | 0x0         | Calibration function Clk16M_RC_enable<br>0: Auto gating<br>1: Soft bypass                                                        |
| 3:2           | R/W        | 0x0         | RC Calibration Precise Selection<br>00: 1ms calibration precise<br>01: 16ms calibration precise<br>10: 128ms calibration precise |
| 1             | R/W        | 0x0         | RC calibration enable<br>0: Close Calibration circuit<br>1: Open Calibration circuit                                             |
| 0             | R/W        | 0x0         | RC CLK SRC SEL<br>Select the RTC 32k clock source from normal RC or Calibrated RC<br>0: Normal RC<br>1: Calibrated RC            |

### 3.12.6.5. 0x0010 RTC DAY Register

| Offset:0x0010 |            |             | Register Name: RTC_DAY_REG        |
|---------------|------------|-------------|-----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                       |
| 31:16         | /          | /           | /                                 |
| 15:0          | R/W        | UDF         | DAY<br>Day<br>Range from 1~65535. |



#### NOTE

Ensure that the bit[7] of LOSC\_CTRL\_REG is 0 before updating RTC\_DAY\_REG.

### 3.12.6.6. 0x0014 RTC HH-MM-SS Register

| Offset:0x0014 |            |             | Register Name: RTC_HH_MM_SS_REG |
|---------------|------------|-------------|---------------------------------|
| Bit           | Read/Write | Default/Hex | Description                     |
| 31:21         | /          | /           | /                               |
| 20:16         | R/W        | UDF         | HOUR<br>Range from 0~23         |
| 15:14         | /          | /           | /                               |
| 13:8          | R/W        | UDF         | MINUTE                          |

|     |     |     |                           |
|-----|-----|-----|---------------------------|
|     |     |     | Range from 0~59           |
| 7:6 | /   | /   | /                         |
| 5:0 | R/W | UDF | SECOND<br>Range from 0~59 |


**NOTE**

Ensure that the bit[8] of LOSC\_CTRL\_REG is 0 before updating RTC\_HH\_MM\_SS\_REG.

### 3.12.6.7. 0x0020 Alarm 0 Day Setting Register (Default Value: 0x0000\_0000)

| Offset:0x0020 |            |             | Register Name: ALARM0_COUNTER_REG                  |
|---------------|------------|-------------|----------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                        |
| 31:16         | /          | /           | /                                                  |
| 15:0          | R/W        | 0x0         | ALARM0_COUNTER<br>Alarm 0 Counter is based on Day. |

### 3.12.6.8. 0x0024 Alarm 0 HH-MM-SS Setting Register

| Offset:0x0024 |            |             | Register Name: ALARM0_CUR_VLU_REG |
|---------------|------------|-------------|-----------------------------------|
| Bit           | Read/Write | Default/Hex | Description                       |
| 31:21         | /          | /           | /                                 |
| 20:16         | R/W        | x           | HOUR<br>Range from 0~23           |
| 15:14         | /          | /           | /                                 |
| 13:8          | R/W        | x           | MINUTE<br>Range from 0~59         |
| 7:6           | /          | /           | /                                 |
| 5:0           | R/W        | x           | SECOND<br>Range from 0~59         |

### 3.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>If this bit is set to “1”, the valid bits of Alarm 0 Counter Register will down count to zero, and the alarm pending bit will be set to “1”.<br>0: Disable<br>1: Enable |

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

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

### 3.12.6.12. 0x0050 Alarm Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0050 |            |             | Register Name: ALARM_CONFIG_REG                                                                                             |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:1          | /          | /           | /                                                                                                                           |
| 0             | R/W        | 0x0         | ALARM_WAKEUP<br>Configuration of alarm wake up output.<br>0: Disable alarm wake up output<br>1: Enable alarm wake up output |

### 3.12.6.13. 0x0060 LOSC OUT Gating Register (Default Value: 0x0000\_0000)

| Offset:0x0060 |            |             | Register Name: LOSC_OUT_GATING_REG                                       |
|---------------|------------|-------------|--------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                              |
| 31:17         | /          | /           | /                                                                        |
| 16            | R/W        | 0x0         | OSC24M_32K_DIVIDER_ENABLE<br>1: enable the OSC24M to 32K divider circuit |

|      |     |     |                                                                                                                                                 |
|------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0: disable the OSC24M to 32K divider circuit                                                                                                    |
| 15:3 | /   | /   | /                                                                                                                                               |
| 2:1  | R/W | 0x0 | LOSC_OUT_SRC_SEL<br>00: RTC_32K(select by RC_CLK_SRC_SEL & LOSC_SRC_SEL)<br>01: LOSC<br>10: OSC24M divided 32K                                  |
| 0    | R/W | 0x0 | 32K_FANOUT_GATING<br>Configuration of LOSC output, and no LOSC output by default.<br>0: Mask LOSC output gating<br>1: Enable LOSC output gating |

### 3.12.6.14. 0x0100+N\*0x0004 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 [31:0]      |



#### NOTE

General purpose register 0~7 value can be stored if the RTC-VIO is larger than 0.7V.

### 3.12.6.15. 0x0120 Fast Boot Information Register0 (Default Value: 0x0000\_0000)

| Offset:0x0120 |            |             | Register Name: FBOOT_INFO_REG0             |
|---------------|------------|-------------|--------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                |
| 31:0          | R/W        | 0x0         | Fast Boot Information, refer to BROM spec. |

### 3.12.6.16. 0x0124 Fast Boot Information Register1 (Default Value: 0x0000\_0000)

| Offset:0x0124 |            |             | Register Name: FBOOT_INFO_REG1             |
|---------------|------------|-------------|--------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                |
| 31:0          | R/W        | 0x0         | Fast Boot Information, refer to BROM spec. |

### 3.12.6.17. 0x0160 DCXO Control Register (Default Value: 0x083F\_10F3 or 0x083F\_F0FC)

| Offset:0x0160 |            |             | Register Name: DCXO_CTRL_REG                                                           |
|---------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                            |
| 31            | R/W        | 0x0         | DCXO_FANOUT_ENB<br>0: enable DCXO wake up function<br>1: disable DCXO wake up function |

|       |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:28 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 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>Capacity 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>0: For external clk input mode<br>1: For normal mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:4   | R/W | 0x3  | DCXO_RFCLK_ENHANCE<br>DCXO rfclk enhance<br>Enhance driving capacity of output OUT_RF_REFCLK, 0x0 for 5pF, 0x1 for 10pF, 0x2 for 15pF, 0x3 for 20pF.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:2   | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1     | R/W | 0x1  | DCXO_EN<br>DCXO enable<br>1: Enable<br>0: Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0     | R/W | 0x1  | CLK16M_RC_EN<br>1: Enable<br>0: Disable<br><br>The related register configuration is necessary to ensure the reset debounce circuit has a stable clock source.<br><br>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.<br><br>Without EXT32K scenario or external RTC scenario, software confirms firstly whether EXT32K is working normally before switching, or software does not close RC16M. |

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

|       |     |     |                                                                                                                                                                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | Wake up DCXO circuit enable.                                                                                                                                                                                                                                                                                                 |
| 30:17 | /   | /   | /                                                                                                                                                                                                                                                                                                                            |
| 16    | R/W | 0x0 | <p>WAKEUP_READY_SLEEP_MODE</p> <p>Calibration wake up ready sleep mode, it must be set before the WAKEUP_DCXO_EN(bit31) 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>0000: 15s<br/>0001: 30s<br/>0010: 45s<br/>0011: 60s<br/>0100: 90s<br/>0101: 120s<br/>0110: 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>0000: 250ms<br/>0001: 500ms<br/>0010: 750ms<br/>0011: 1s<br/>0100: 1.25s<br/>0101: 1.5s<br/>0110: 1.75s<br/>0111: 2s<br/>1000: 2.25s<br/>1001: 2.5s<br/>1010: 2.75s<br/>1011: 3s<br/>1100: 3.25s<br/>1101: 3.5s<br/>1110: 3.75s<br/>1111: 4s</p> |
| 7:4   | R/W | 0x4 | <p>WAKEUP_CNT FOR SLEEP</p> <p>Wake up counter for sleep</p> <p>0000: 250ms<br/>0001: 500ms<br/>0010: 1s<br/>0011: 10s<br/>0100: 60s<br/>0101: 120s<br/>0110: 180s<br/>0111: 240s</p>                                                                                                                                        |

|     |     |     |                                                                                                                                    |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 1000: 300s<br>1001: 360s<br>1010: 420s<br>1011: 480s<br>1100: 540s<br>1101: 600s<br>1110: 1200s<br>1111: 1800s                     |
| 3:0 | R/W | 0x3 | WAIT DCXO SEL<br>Select for DCXO active after DCXO enable<br>0000: 1ms<br>0001: 2ms<br>0010: 3ms<br>0011: 4ms<br>...<br>1111: 16ms |

### 3.12.6.19. 0x0190 RTC\_VIO Regulation Register (Default Value: 0x0000\_0004)

| Offset:0x0190 |            |             | Register Name:RTC_VIO_REG                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:5          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4             | R/W        | 0x0         | V_SEL<br>0: resistance divider<br>1: band gap                                                                                                                                                                                                                                                                                                                                                                                    |
| 3             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2:0           | R/W        | 0x4         | RTC_VIO_REGU<br>These bits are useful for regulating the RTC_VIO from 0.6V to 1.3V, and the regulation step is 0.1V.<br>000: 1.0V<br>001: 0.6V (the configuration can cause RTC reset)<br>010: 0.7V<br>011: 0.8V<br>100: 0.9V<br>101: 1.1V<br>110: 1.2V<br>111: 1.3V<br>RTC-VIO is provided power for RTC digital part, the default value is 0.9V.<br>After power-on, software sets the field to 0.8V to save power-consumption. |

### 3.12.6.20. 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         | IC_CHARA<br>Key Field<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>Return 0x16AA only if the KEY_FIELD is set as 0x16AA when read those bits, otherwise return 0x0.                   |

### 3.12.6.21. 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_1.8V_POWER_SWITCH_CONTROL<br>1: open power switch<br>0: close power switch |

### 3.12.6.22. 0x0310 RTC SPI Clock Control Register (Default Value: 0x0000\_0000)

| Offset:0x0310 |            |             | Register Name: RTC_SPI_CLK_CTRL_REG                                                                                                                                                                                                                                           |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| 31            | R/W        | 0x0         | 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><b>Note: Frequency division and clock gating can not be set at the same time.</b> |
| 30:5          | /          | /           | /                                                                                                                                                                                                                                                                             |
| 4:0           | R/W        | 0x9         | RTC Reg CFG SPI Clock Divider: M<br>Actual SPI Clock = AHBS1/(M+1), (0~15)<br>The default frequency of AHBS1 is 200MHz, and the default frequency of SPI Clock is 20MHz.<br><b>Note: The SPI clock can not exceed 50MHz, or else RTC register may be abnormal.</b>            |

## 3.13. Message Box

### 3.13.1. Overview

The Message Box(MSGBOX) provides interrupt communication mechanism for on-chip processor.

The MSGBOX has the following features:

- Eight message queues
- Each of queues could be configured as transmitter or receiver for user
- FIFO depth is  $4 \times 32$  bits
- The communication parties are CPUS and CPUX
- The communication parties transmit information through channel
- Message reception and queue-not-full notification interrupt mechanism

### 3.13.2. Block Diagram



Figure 3- 38. Message Box Block Diagram

Message Box supports a set of registers for a processor to establish an interconnection channel with the others. The processor determines message queue numbers for interconnection and the used queues to be transmitter or receiver for itself and the interconnectible one. Every queue has a **MSGBox FIFO Status Register** for processor to check out queue FIFO full status and a **MSGBox Message Status Register** for processor to check out message numbers in queue FIFO. Otherwise, every queue has a corresponding IRQ status bit and a corresponding IRQ enable bit, which are used for requesting an interrupt.

### 3.13.3. Operations and Functional Descriptions

#### 3.13.3.1. Clock and Reset

MSGBOX is on AHB1 bus. To access MSGBOX, perform the following steps about AHB1 bus.

Step1: De-assert MSGBOX reset signal.

Step2: Open MSGBOX gating signal.

#### 3.13.3.2. Typical Application

Two different CPU can build communication by configuring MSGBOX. The communication parties have 8 bidirectional channels. If a party is receiver, then another is transmitter. During communication process, the current status can be judged through interrupt or FIFO status.



Figure 3- 39. Message Box Typical Application Chart

### 3.13.3.3. Message Queue Assignment

When a processor needs to transmit or receive a message from the other one, it should configure the Message Queue assignment for the other one and itself. **MSGBOX\_CTRL\_REG0** and **MSGBOX\_CTRL\_REG1** hold the eight Message Queues assignment. For an instance, The **RECEPTION\_MQ0** bit is set to 0 and the **TRANSMIT\_MQ0** bit is set to 1, that means, user1 transmits messages and user0 receives them. Or the **RECEPTION\_MQ0** bit and the **TRANSMIT\_MQ0** bit are both set to 0, which means user0 transmits messages to itself.

### 3.13.3.4. Interrupt Request

Message Box provides message reception and queue-not-full notification interrupt mechanism. When a message queue is configured as transmitter for a user, this queue transmit pending bit will always be set to 1 for this user if it is not full. When a message queue is configured as receiver for a user, this queue reception pending bit will be set to 1 for this user only if it receives a new message. For example, message queue0 is configured as a transmitter for user0 and a receiver for user1. If message queue0 is not full always, then **TRANSMIT\_MQ0\_IRQ\_PEND** bit is set to 1. If **TRANSMIT\_MQ0\_IRQ\_EN** is set to 1, user0 will request a queue-not-full interrupt. When message queue0 has received

a new message, RECEPTION\_MQ0\_IRQ\_PEND would be set to 1 and user1 will request a new message reception interrupt if RECEPTION\_MQ0\_IRQ\_EN is set to 1. **MSGBox IRQ Status Register u(u=0,1)** hold the IRQ status for user0 and user1. **MSGBox IRQ Enable Register u(u=0,1)** determines whether the user could request the interrupt or not.

### 3.13.3.5. Transmit and Receive Messages

Every message queue has a couple of private registers for query: **MSGBox Message Status Register**, **MSGBox FIFO Status Register**, and **MSGBox Message Queue Register**.

**MSGBox Message Status Register** records present message number in the message queue.

**MSGBox FIFO Status Register** indicates whether the message queue is full obviously.

**MSGBox Message Queue Register** stores the next to be read message of the message FIFO queue or the message to be written into the queue FIFO. If queue is not full usually ,it indicates that you could write messages into the queue FIFO ,if there is one or more message in the queue FIFO, it indicates that you could read messages from the queue FIFO.

Writing a message into the queue FIFO realizes a transmission and reading a message makes a reception ture. You could transmit messages by writing messages to **MSGBox Message Queue Register** continuously or receive messages by reading **MSGBox Message Queue Register** continuously. The continuous writing or reading operation means it's no need to make a delay between operations.

### 3.13.3.6. Operating Mode

#### 3.13.3.6.1. Transfer Mode Configuration

- Queue n (n=0~3) transmitter mode: Write 1 to the bit[8\*n+4] of **MSGBOX\_CTRL\_REG0**.
- Queue m (m=4~7) transmitter mode : Write 1 to the bit[8\*(m-4)+4] of **MSGBOX\_CTRL\_REG1**.
- Queue n (n=0~3) receiver mode: Write 1 to the bit[8\*n] of **MSGBOX\_CTRL\_REG0**.
- Queue m (m=4~7) receiver mode : Write 1 to the bit[8\*(m-4)] of **MSGBOX\_CTRL\_REG1**.

#### 3.13.3.6.2. Interrupt Check Transfer Status

- (1) Configure transmitter and receiver mode through **chapter 3.13.3.6.1. Transfer Mode Configuration**.
- (2) Interrupt enable bit: Configure the interrupt enable bit of transmitter/receiver through **MSGBOX\_IRQ\_EN\_REG**.
- (3) When FIFO is not full, an interrupt pending generates to remind the transmitter to transmit data, at this time, to write data to FIFO in interrupt handler ,and clear the pending bit and the enable bit of *Transmitter IRQ*.
- (4) When FIFO has new data, an interrupt pending generates to remind the receiver to receive data, at this time, to read data from FIFO in interrupt handler, and clear the pending bit and the enable bit of *Receiver IRQ*.

### 3.13.3.6.3. FIFO Check Transfer Status

- (1) Configure transmitter and receiver mode through **chapter 3.13.3.6.1. Transfer Mode Configuration**.
- (2) When FIFO is not full, the transmitter fills FIFO to 4\*32 bits.
- (3) When the receiver considers FIFO is full, then the receiver reads FIFO data, and reads **MSGBOXM\_MSG\_STATUS\_REG** to require the current FIFO number.

### 3.13.3.6.4. Debug

To use MSGBOX in debug mode, performs the following steps:

- (1) Write 1 to the bit0 of **MSGBOX\_DEBUG\_REG**.
- (2) The control bit of the corresponding channel is set to 1.

### 3.13.4. Programming Guidelines

Example: User1 as transmitter of MQ0123 (MQ:Message Queue) and as receiver of MQ4567, User0 as receiver of MQ0123 and as transmitter of MQ4567.

The working process of user1 and user0 is as follows.



Figure 3- 40. User1 and User0 Working Process

#### User1:

- (a) The user1 is as the transmitter of MQ0123 and as the receiver of MQ4567.
- (b) Queue n ( $n=0\sim 3$ ) transmitter mode: write 1 to the bit[8\*n+4] of **MSGBOX\_CTRL\_REG0**.
- (b') Queue m ( $m=4\sim 7$ ) receiver mode: write 1 to the bit[8\*(m-4)] of **MSGBOX\_CTRL\_REG1**.

- (c) Check whether the FIFO is full by the status of MSGBOXM\_FIFO\_STATUS\_REG. If the FIFO is full, the program finish, otherwise, go to step (d).
- (c') Check whether to receive a message by the status of MSGBOXM\_MSG\_STATUS\_REG. If you donot receive, then continue to wait, otherwise, go to step (d').
- (d) Write a message to MSGBOXM\_MSG\_REG.
- (d') Read MSGBOX\_MSG\_REG to fetch the message.
- (e) If there is no message in FIFO Queue, step up to (d'), otherwise, the program finish.

**User0:**

- (a) The user0 is as the receiver of MQ0123.
- (a') The user0 is as the transmitter of MQ4567.
- (b) Check whether to receive a message by the status of MSGBOXM\_MSG\_STATUS\_REG. If you donot receive, then continue to wait, otherwise, go to step (c).
- (b') Check whether the FIFO is full by the status of MSGBOXM\_FIFO\_STATUS\_REG. If the FIFO is full, the program finish, otherwise, step up to (c').
- (c) Read MSGBOX\_MSG\_REG to fetch the message.
- (c') Write a message to MSGBOXM\_MSG\_REG.
- (d) If there is no message in FIFO Queue, go to step (c), otherwise, the program finish.

**3.13.5. Register List**

| Module Name | Base Address |
|-------------|--------------|
| MSGBOX      | 0x03003000   |

| Register Name           | Offset        | Description                                 |
|-------------------------|---------------|---------------------------------------------|
| MSGBOX_CTRL_REG0        | 0x0000        | Message Queue Attribute Control Register 0  |
| MSGBOX_CTRL_REG1        | 0x0004        | Message Queue Attribute Control Register 1  |
| MSGBOXU_IRQ_EN_REG      | 0x0040+n*0x20 | IRQ Enable for User n (n=0,1)               |
| MSGBOXU_IRQ_STATUS_REG  | 0x0050+n*0x20 | IRQ Status for User n (n=0,1)               |
| MSGBOXM_FIFO_STATUS_REG | 0x0100+N*0x04 | FIFO Status for Message Queue N(N = 0~7)    |
| MSGBOXM_MSG_STATUS_REG  | 0x0140+N*0x04 | Message Status for Message Queue N(N=0~7)   |
| MSGBOXM_MSG_REG         | 0x0180+N*0x04 | Message Register for Message Queue N(N=0~7) |
| MSGBOX_DEBUG_REG        | 0x01C0        | MSGBOX Debug Register                       |

**3.13.6. Register Description****3.13.6.1. MSGBox Control Register 0(Default Value: 0x1010\_1010)**

| Offset: 0x0000 |            |             | Register Name: MSGBOX_CTRL_REG0 |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:29          | /          | /           | /                               |

|       |     |     |                                                                                    |
|-------|-----|-----|------------------------------------------------------------------------------------|
| 28    | R/W | 0x1 | TRANSMIT_MQ3<br>Message Queue 3 is a transmitter of user u<br>0: user0<br>1: user1 |
| 27:25 | /   | /   | /                                                                                  |
| 24    | R/W | 0x0 | RECEPTION_MQ3<br>Message Queue 3 is a receiver of user u<br>0: user0<br>1: user1   |
| 23:21 | /   | /   | /                                                                                  |
| 20    | R/W | 0x1 | TRANSMIT_MQ2<br>Message Queue 2 is a transmitter of user u<br>0: user0<br>1: user1 |
| 19:17 | /   | /   | /                                                                                  |
| 16    | R/W | 0x0 | RECEPTION_MQ2<br>Message Queue 2 is a receiver of user u<br>0: user0<br>1: user1   |
| 15:13 | /   | /   | /                                                                                  |
| 12    | R/W | 0x1 | TRANSMIT_MQ1<br>Message Queue 1 is a transmitter of user u<br>0: user0<br>1: user1 |
| 11:9  | /   | /   | /                                                                                  |
| 8     | R/W | 0x0 | RECEPTION_MQ1<br>Message Queue 1 is a receiver of user u<br>0: user0<br>1: user1   |
| 7:5   | /   | /   | /                                                                                  |
| 4     | R/W | 0x1 | TRANSMIT_MQ0<br>Message Queue 0 is a transmitter of user u<br>0: user0<br>1: user1 |
| 3:1   | /   | /   | /                                                                                  |
| 0     | R/W | 0x0 | RECEPTION_MQ0<br>Message Queue 0 is a receiver of user u<br>0: user0<br>1: user1   |

### 3.13.6.2. MSGBox Control Register 1(Default Value: 0x1010\_1010)

|                |                                 |
|----------------|---------------------------------|
| Offset: 0x0004 | Register Name: MSGBOX_CTRL_REG1 |
|----------------|---------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                        |
|-------|------------|-------------|------------------------------------------------------------------------------------|
| 31:29 | /          | /           | /                                                                                  |
| 28    | R/W        | 0x1         | TRANSMIT_MQ7<br>Message Queue 7 is a transmitter of user u<br>0: user0<br>1: user1 |
| 27:25 | /          | /           | /                                                                                  |
| 24    | R/W        | 0x0         | RECEPTION_MQ7<br>Message Queue 7 is a receiver of user u<br>0: user0<br>1: user1   |
| 23:21 | /          | /           | /                                                                                  |
| 20    | R/W        | 0x1         | TRANSMIT_MQ6<br>Message Queue 6 is a transmitter of user u<br>0: user0<br>1: user1 |
| 19:17 | /          | /           | /                                                                                  |
| 16    | R/W        | 0x0         | RECEPTION_MQ6<br>Message Queue 6 is a receiver of user u<br>0: user0<br>1: user1   |
| 15:13 | /          | /           | /                                                                                  |
| 12    | R/W        | 0x1         | TRANSMIT_MQ5<br>Message Queue 5 is a transmitter of user u<br>0: user0<br>1: user1 |
| 11:9  | /          | /           | /                                                                                  |
| 8     | R/W        | 0x0         | RECEPTION_MQ5<br>Message Queue 5 is a receiver of user u<br>0: user0<br>1: user1   |
| 7:5   | /          | /           | /                                                                                  |
| 4     | R/W        | 0x1         | TRANSMIT_MQ4<br>Message Queue 4 is a transmitter of user u<br>0: user0<br>1: user1 |
| 3:1   | /          | /           | /                                                                                  |
| 0     | R/W        | 0x0         | RECEPTION_MQ4<br>Message Queue 4 is a receiver of user u<br>0: user0<br>1: user1   |

### 3.13.6.3. MSGBox IRQ Enable Register u(Default Value: 0x0000\_0000)

| Offset:0x0040+N*0x20(N=0,1) |            | Register Name: MSGBOX_IRQ_EN_REG |                                                                                                                                       |
|-----------------------------|------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit                         | Read/Write | Default/Hex                      | Description                                                                                                                           |
| 31:16                       | /          | /                                | /                                                                                                                                     |
| 15                          | R/W        | 0x0                              | TRANSMIT_MQ7_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 7 is not full.)                 |
| 14                          | R/W        | 0x0                              | RECEPTION_MQ7_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 7 has received a new message.) |
| 13                          | R/W        | 0x0                              | TRANSMIT_MQ6_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 6 is not full.)                 |
| 12                          | R/W        | 0x0                              | RECEPTION_MQ6_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 6 has received a new message.) |
| 11                          | R/W        | 0x0                              | TRANSMIT_MQ5_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 5 is not full.)                 |
| 10                          | R/W        | 0x0                              | RECEPTION_MQ5_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 5 has received a new message.) |
| 9                           | R/W        | 0x0                              | TRANSMIT_MQ4_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 4 is not full.)                 |
| 8                           | R/W        | 0x0                              | RECEPTION_MQ4_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 4 has received a new message.) |
| 7                           | R/W        | 0x0                              | TRANSMIT_MQ3_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 3 is not full.)                 |
| 6                           | R/W        | 0x0                              | RECEPTION_MQ3_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 3 has received a new message.) |

|   |     |     |                                                                                                                                       |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 5 | R/W | 0x0 | TRANSMIT_MQ2_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 2 is not full.)                 |
| 4 | R/W | 0x0 | RECEPTION_MQ2_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 2 has received a new message.) |
| 3 | R/W | 0x0 | TRANSMIT_MQ1_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 1 is not full.)                 |
| 2 | R/W | 0x0 | RECEPTION_MQ1_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 1 has received a new message.) |
| 1 | R/W | 0x0 | TRANSMIT_MQ0_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 0 is not full.)                 |
| 0 | R/W | 0x0 | RECEPTION_MQ0_IRQ_EN<br>0: Disable<br>1: Enable (It will notify user u by interrupt when Message Queue 0 has received a new message.) |

### 3.13.6.4. MSGBox IRQ Status Register u(Default Value: 0x0000\_AAAA)

| Offset:0x0050+N*0x20(N=0,1) |            |             | Register Name: MSGBOXU_IRQ_STATUS_REG                                                                                                                                           |
|-----------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                         | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31:16                       | /          | /           | /                                                                                                                                                                               |
| 15                          | R/W1C      | 0x1         | TRANSMIT_MQ7_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 7 is not full. Setting 1 to this bit will clear it.                 |
| 14                          | R/W1C      | 0x0         | RECEPTION_MQ7_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 7 has received a new message. Setting 1 to this bit will clear it. |
| 13                          | R/W1C      | 0x1         | TRANSMIT_MQ6_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 6 is not full. Setting 1 to this bit will clear it.                 |
| 12                          | R/W1C      | 0x0         | RECEPTION_MQ6_IRQ_PEND<br>0: No effect                                                                                                                                          |

|    |       |     |                                                                                                                                                                                 |
|----|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | 1: Pending. This bit will be pending for user u when Message Queue 6 has received a new message. Setting 1 to this bit will clear it.                                           |
| 11 | R/W1C | 0x1 | TRANSMIT_MQ5_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 5 is not full. Setting 1 to this bit will clear it.                 |
| 10 | R/W1C | 0x0 | RECEPTION_MQ5_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 5 has received a new message. Setting 1 to this bit will clear it. |
| 9  | R/W1C | 0x1 | TRANSMIT_MQ4_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 4 is not full. Set 1 to this bit will clear it.                     |
| 8  | R/W1C | 0x0 | RECEPTION_MQ4_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 4 has received a new message. Setting 1 to this bit will clear it. |
| 7  | R/W1C | 0x1 | TRANSMIT_MQ3_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 3 is not full. Setting 1 to this bit will clear it.                 |
| 6  | R/W1C | 0x0 | RECEPTION_MQ3_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 3 has received a new message. Setting 1 to this bit will clear it. |
| 5  | R/W1C | 0x1 | TRANSMIT_MQ2_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 2 is not full. Setting 1 to this bit will clear it.                 |
| 4  | R/W1C | 0x0 | RECEPTION_MQ2_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 2 has received a new message. Setting 1 to this bit will clear it. |
| 3  | R/W1C | 0x1 | TRANSMIT_MQ1_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 1 is not full. Setting 1 to this bit will clear it.                 |
| 2  | R/W1C | 0x0 | RECEPTION_MQ1_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 1 has received a new message. Setting 1 to this bit will clear it. |
| 1  | R/W1C | 0x1 | TRANSMIT_MQ0_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user u when Message Queue 0 is not full. Setting 1 to this bit will clear it.                 |

|   |       |     |                                                                                                                                                                                          |
|---|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | full. Setting 1 to this bit will clear it.                                                                                                                                               |
| 0 | R/W1C | 0x0 | <p>RECEPTION_MQ0_IRQ_PEND<br/>0: No effect<br/>1: Pending. This bit will be pending for user u when Message Queue 0 has received a new message. Setting 1 to this bit will clear it.</p> |

### 3.13.6.5. MSGBox FIFO Status Register m(Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x04 (N=0~7) |            |             | Register Name: MSGBOXM_FIFO_STATUS_REG                                                                                                                                                                 |
|------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                            |
| 31:1                         | /          | /           | /                                                                                                                                                                                                      |
| 0                            | R          | 0x0         | <p>FIFO_FULL_FLAG<br/>0: The Message FIFO queue is not full (space is available)<br/>1: The Message FIFO queue is full.<br/>This FIFO status register has the status related to the message queue.</p> |

### 3.13.6.6. MSGBox Message Status Register m(Default Value: 0x0000\_0000)

| Offset:0x0140+N*0x04 (N=0~7) |            |             | Register Name: MSGBOXM_MSG_STATUS_REG                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:3                         | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2:0                          | R          | 0x0         | <p>MSG_NUM<br/>Number of unread messages in the message queue. Here, limited to four messages per message queue.<br/>000: There is no message in the message FIFO queue.<br/>001: There is 1 message in the message FIFO queue.<br/>010: There are 2 messages in the message FIFO queue.<br/>011: There are 3 messages in the message FIFO queue.<br/>100: There are 4 messages in the message FIFO queue.<br/>101~111:/</p> |

### 3.13.6.7. MSGBox Message Queue Register m(Default Value: 0x0000\_0000)

| Offset:0x0180+N*0x04 (N=0~7) |            |             | Register Name: MSGBOXM_MSG_REG                                                                                                   |
|------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:0                         | R/W        | 0x0         | The message register stores the next to be read message of the message FIFO queue. Reads remove the message from the FIFO queue. |

### 3.13.6.8. MSGBox Debug Register(Default Value: 0x0000\_0000)

| Offset: 0x01C0 |            |             | Register Name: MSGBOX_DEBUG_REG                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:16          | /          | /           | /                                                                                                                                                                                                                             |
| 15:8           | R/W        | 0x0         | FIFO_CTRL<br>MQ[7:0] Control.<br>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>In the debug mode, each user can transmit messages to itself through each message queue.<br>0: Normal Mode<br>1: Debug Mode                                                                                     |

## 3.14. Spinlock

### 3.14.1. Overview

In multi-core system, the Spinlock offers hardware synchronization mechanism, lock operation can prevent multi processors from handling data-sharing at the same time, and ensure coherence of data.

The Spinlock has the following features:

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

### 3.14.2. Block Diagram



Figure 3- 41. Spinlock Block Diagram

### 3.14.3. Operations and Functional Descriptions

#### 3.14.3.1. Clock and Reset

The Spinlock is hung on AHB1. Before accessing Spinlock register, open the corresponding gating bit on AHB1 and de-assert reset signal. The correct operation order is to de-assert reset signal at first, and then open the corresponding gating signal.

#### 3.14.3.2. Typical Application

A processor lock spinlock0, when the status is locked, the processor executes specific code, and then unlocks code. Other processors is released to start reading/writing operation.



Figure 3- 42. Spinlock Typical Application Diagram

### 3.14.3.3. Function Implementation

#### 3.14.3.3.1. Spinlock State Machine

When a processor uses the spinlock, it needs to acquire the status of the spinlock through **SPINLOCK\_STATUS\_REG**.

**Reading operation:** when the return value is 0, the spinlock comes into locked status; when read this status bit again, the return value is 1, the spinlock comes into locked status.

**Writing operation:** when the spinlock is in locked status, the spinlock can convert to unlocked status through writing 0. After reset, the spinlock is in unlocked status by default.



Figure 3- 43. Spinlock State Machine

### 3.14.3.3.2. Take and Free Spinlock

Checking out **SpinLock Register Status** is necessary when a processor takes a spinlock. This register stores the status of all 32 lock registers: TAKEN or NOT TAKEN(free).

In order to request to take a spinlock, a processor has to do a read-access to the corresponding lock register. If lock register returns 0, the processor takes this spinlock. And if lock register returns 1, the processor must retry.

Writing 0 to a lock register frees the corresponding spinlock. If the lock register is not taken, write-access has no effect. For a taken spinlock, every processor has the privilege to free this spinlock. But it is suggested that the processor which has taken the spinlock free it for strictness.

### 3.14.3.4. Operating Mode

#### 3.14.3.4.1. Switch Status

- (1) When the read value from **SPINLOCKN\_LOCK\_REG** is 0, the spinlock come into locked status.
- (2) Execute application code, the status of **SPINLOCKN\_STATUS\_REG** is 1.
- (3) Write 0 to **SPINLOCKN\_LOCK\_REG**, the spinlock comes into unlocked status, corresponding spinlock is released.

### 3.14.4. Programming Guidelines

Take CPU0 synchronization of Spinlock0 for an example, CPU0 takes the spinlock0 firstly in the instance.

To taking/freeing spinlock0, CPU0 and CPUS perform the following steps:



Figure 3- 44. CPU0 and CPUS Taking/Freeing Spinlock0 Process

**CPU0:**

- (a) The CPU0 initializes Spinlock.
- (b) Firstly, check lock register0(SPINLOCK\_STATUS\_REG0) status, if it is taken, check till CPU0 frees spinlock0. Then request to take spinlock0, if fail, retry till lock register0 is taken.
- (c) Execute CPU0 critical code.
- (d) After executing CPU0 critical code, the CPU0 frees spinlock0.
- (e) The CPU0 waits for the freeing spinlock0 of CPUS.

**CPUS:**

- (a) If the CPU0 has taken spinlock0, the CPUS waits for the freeing spinlock0 of CPU0.
- (b) The CPUS requests to take spinlock0, if fail, retry till lock register0 is taken.
- (c) Execute CPUS critical code.
- (d) After executing CPUS critical code, the CPUS frees spinlock0.

The following codes are for reference.

**CPU0 of Cluster0**

## Step 1: CPU0 initializes Spinlock

```
put_wvalue(SPINLOCK_BGR_REG,0x00010000);
put_wvalue(SPINLOCK_BGR_REG,0x00010001);
```

## Step 2: CPU0 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 CPU0 frees spinlock0
rdata=readl(SPINLOCK_LOCK_REG0);              //Request to take spinlock0
if(rdata != 0)    rdata=readl(SPINLOCK_LOCK_REG0); //If fail, retry till lock register0 is taken
```

----- CPU0 critical code section -----

## Step 3: CPU0 free spinlock0

```
writel(0, SPINLOCK_LOCK_REG0);                //CPU0 frees spinlock0
```

## Step 4: CPU0 waits for CPUS' freeing spinlock0

```
writel(readl(SPINLOCK_STATUS_REG0) == 1);      //CPU0 waits for the freeing spinlock0 of CPUS
```

**CPUS**

## Step 1: CPU0 has taken spinlock0, CPUS waits for CPU0' freeing spinlock0

```
while(readl(SPINLOCK_STATUS_REG0) == 1);          //CPUS waits for the freeing spinlock0 of CPU0
```

## Step 2: CPUS takes spinlock0 and go on

```
rdata=readl(SPINLOCK_LOCK_REG0);                  //Request to take spinlock0
if(rdata != 0)    rdata=readl(SPINLOCK_LOCK_REG0); //If fail, retry till lock register0 is taken
```

----- CPUS critical code section -----

## Step 3: CPUS frees spinlock0

```
writel(0, SPINLOCK_LOCK_REG0);                  //CPUS frees spinlock0
```

**3.14.5. Register List**

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|          |           |
|----------|-----------|
| Spinlock | 0x3004000 |
|----------|-----------|

| Register Name         | Offset        | Description                     |
|-----------------------|---------------|---------------------------------|
| SPINLOCK_SYSTATUS_REG | 0x0000        | Spinlock System Status Register |
| SPINLOCK_STATUS_REG   | 0x0010        | Spinlock Status Register        |
| SPINLOCK_LOCK_REGN    | 0x0100+N*0x04 | Spinlock Register N (N=0~31)    |

### 3.14.6. Register Description

#### 3.14.6.1. 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 32 lock registers<br>01: This instance has 64 lock registers<br>10: This instance has 128 lock registers<br>11: This instance has 256 lock registers |
| 27:9           | /          | /           | /                                                                                                                                                                                                                               |
| 8              | R          | 0x0         | IU0<br>In-Use flag0, covering lock register0-31<br>0: All lock register 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            | /          | /           | /                                                                                                                                                                                                                               |

#### 3.14.6.2. Spinlock Register Status(Default Value: 0x0000\_0000)

| Offset: 0x0010  |            |             | Register Name: SPINLOCK_STATUS_REG                                                                    |
|-----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit             | Read/Write | Default/Hex | Description                                                                                           |
| [i]<br>(i=0~31) | R          | 0x0         | LOCK_REG_STATUS<br>SpinLock[i] status (i=0~31)<br>0: The Spinlock is free<br>1: The Spinlock is taken |

#### 3.14.6.3. Spinlock Register N (N=0 to 31)(Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x04 (N=0~31) |            | Register Name: SPINLOCKN_LOCK_REG |             |
|-------------------------------|------------|-----------------------------------|-------------|
| Bit                           | Read/Write | Default/Hex                       | Description |

| 31:1 | /   | /   | /                                                                                                                                                                                                                                                                                                                                  |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | R/W | 0x0 | <p>TAKEN<br/>Lock State</p> <p>Read 0x0: The lock was previously Not Taken (free). The requester is granted the lock.</p> <p>Write 0x0: Set the lock to Not Taken (free).</p> <p>Read 0x1: The lock was previously Taken. The requester is not granted the lock and must retry.</p> <p>Write 0x1: No update to the lock value.</p> |

Confidential

## Contents

---

|                                   |     |
|-----------------------------------|-----|
| Chapter 4 Video and Graphics..... | 312 |
| 4.1. DE .....                     | 312 |
| 4.2. G2D.....                     | 313 |
| 4.3. Video Decoding.....          | 314 |
| 4.3.1. Overview .....             | 314 |
| 4.3.2. Block Diagram .....        | 315 |
| 4.4. Video Encoding .....         | 316 |
| 4.4.1. VE .....                   | 316 |
| 4.4.2. JPEG.....                  | 318 |

Confidential

## Figures

---

|                                                |     |
|------------------------------------------------|-----|
| Figure 4- 1. DE Block Diagram.....             | 312 |
| Figure 4- 2. Video Decoding Block Diagram..... | 315 |
| Figure 4- 3. VE Block Diagram.....             | 317 |
| Figure 4- 4. JPGE Block Diagram.....           | 319 |

Confidential

# Chapter 4 Video and Graphics

## 4.1. DE

The Display Engine (DE) is a hardware composer to transfer image layers from a local bus or a video buffer to the LCD interface. The DE supports four overlay windows to blend, and supports image post-processing in the video channel. The block diagram of DE is shown in Figure 4-1.

The DE has the following features:

- Output size up to 2048 x 2048
- Four alpha blending channels for main display, three channels for aux display
- Four overlay layers in each channel, and has a independent scaler
- Potter-duff compatible blending operation
- Input format: YUV422/YUV420/YUV411/ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555 and RGB565
- Frame Packing/Top-and-Bottom/Side-by-Side Full/Side-by-Side Half 3D format data
- Supports SmartColor2.0 for excellent display experience
  - Adaptive detail/edge enhancement
  - Adaptive color enhancement and fresh tone rectify
  - Adaptive contrast enhancement
  - Content adaptive backlight control
- Supports write back only for high efficient main display and miracast



Figure 4- 1. DE Block Diagram

## 4.2. G2D

The Graphic 2D (G2D) engine is hardware accelerator for 2D graphic.

The G2D has the following features:

- Supports layer size up to 2048 x 2048 pixels
- Supports input/output formats: YUV422 (semi-planar and planar format)/YUV420 (semi-planar and planar format)/P010/P210/P410/Y8/ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555/ARGB2101010 and RGB565
- Supports horizontal and vertical flip, clockwise 0/90/180/270 degree rotate

## 4.3. Video Decoding

### 4.3.1. Overview

The Video Decoding consists of Video Control Firmware(VCF) running on ARM processor and embedded hardware Video Engine(VE). VCF gets the bitstream from topper software, parses bitstream, invokes the Video Engine, and generates the decoding image sequence. The decoder image sequence is transmitted by the video output controller to the display device under the control of the topper software.

The Video Decoding has the following features:

- Supports ITU-T H.265 Main Profile@Level 5.0
  - Maximum video resolution: 4096 x 2048
  - Maximum decoding rate: 60 Mbps, 4K@30fps(enable afbc mode, and the second scaler is 1080p output to display)
- Supports ITU-T H.264 Base/Main/High Profile@Level 5.1
  - Maximum video resolution: 4096 x 2048
  - Maximum decoding rate: 60 Mbps, 4K@30fps(enable afbc mode, and the second scaler is 1080p output to display)
- Supports VP9
  - Maximum video resolution: 1280 x 720
  - Maximum decoding rate: 4 Mbps, 720p@30fps
- Supports AVS/AVS+
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 30 Mbps, 1080p@60fps
- Supports ITU-T H.263 Base Profile
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbps, 1080p@60fps
- Supports VP8
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 40 Mbps, 1080p@60fps
- Supports VC-1 SP/MP/AP
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbps, 1080p@30fps
- Supports MPEG-4 SP/ASP
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbps, 1080p@60fps
- Supports MPEG-2 MP/HL
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbps, 1080p@60fps
- Supports MPEG-1 MP/HL
  - Maximum video resolution: 1920 x 1080

- Maximum decoding rate: 60 Mbps, 1080p@60fps
- Supports MJPEG
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbps, 1080p@60fps

#### 4.3.2. Block Diagram

The functional block diagram of the Video Decoding is as follows.



Figure 4- 2. Video Decoding Block Diagram

## 4.4. Video Encoding

The Video Encoding consists of the video encoding unit(VE) and JPEG encoder(JPGE). The VE supports H.264 encoding, and JPGE supports JPEG/MJPEG encoding.

### 4.4.1. VE

#### 4.4.1.1. Overview

The VE is a H.264 encoding accelerator implemented by using hardware. It features low CPU usage, short delay and low power consumption.

The VE has the following features:

- Supports ITU-T H.264 high profile/main profile/baseline profile@level 5.2 encoding
  - Encoding of multiple slice
  - Motion compensation with 1/2 and 1/4 pixel precision
  - Four prediction unit (PU) types of 16x8, 8x16, 16x16 and 8x8 for inter-prediction
  - Two prediction unit types of Intra16x16 and Intra4x4 for intra-prediction
  - Trans4x4
  - CABAC and CAVLC entropy encoding
  - De-blocking filtering
- Supports Classify, MB-RateControl, Fore-3D-Filter, Cyclic-Intra-Refresh, Dynamic-ME and Intra-4x4-Disable Functions in general
- Supports the input picture format of semi-planar YCbCr4:2:0
- Supports H.264 encoding with the performance of 8-megapixel 1080p@60fps
- Supports configurable picture resolutions
  - Minimum picture resolution: 192 x 96
  - Maximum picture resolution: 4096 x 4096
  - Step of the picture width or height: 8
- Supports region of interest (ROI) encoding
  - Maximum of 4 ROIs
  - Independent enable/disable control for the encoding function of each ROI
- Supports on-screen display (OSD) encoding protection that can be enabled or disabled
- Supports OSD front-end overlaying
  - OSD overlaying before encoding for a maximum of 16 regions
  - OSD overlaying with any size and at any position (within the size and position range of the picture)
  - 16-level alpha blending
  - OSD overlaying control (enabled or disabled)
- Supports three bit rate control modes: constant bit rate (CBR), variable bit rate (VBR) and FIXQP
- Supports the output bit rate ranging from 2 kbit/s to 60 Mbit/s
- Supports Frame Buffer Compression

#### 4.4.1.2. Block Diagram

The functional block diagram of the VE is as follows.



Figure 4- 3. VE Block Diagram

Based on related protocols and algorithms, the VE supports motion estimation/inter-prediction, intra-prediction, transform/quantization, inverse transform/inverse quantization, CABAC encoding/stream generation and DeBlock/SAO. The ARM software controls the bit-rate and handles interrupt.

Before the VE is enabled for video encoding, software allocates three types of buffers mainly in the external DDR SDRAM:

- **Input picture buffer**

The VE reads the source pictures to be encoded from this buffer during encoding. This buffer is typically written by the Video Input Port module.

- **Reconstruction/Reference picture buffer**

The VE writes reconstruction pictures to this buffer during encoding. These reconstruction pictures are used as the reference pictures of subsequent pictures. During the encoding of P frames, the reference pictures are read from this buffer.

- **Stream buffer**

This buffer stores encoded streams. The VE writes streams to this buffer during encoding. This buffer is read by software.

## 4.4.2. JPGE

### 4.4.2.1. Overview

The JPGE is a high-performance JPEG encoder implemented by using hardware. It supports 64-megapixel snapshot or HD MJPEG encoding.

The JPGE has the following features:

- Supports ISO/IEC 10918-1 (CCITT T.81) baseline process (DCT sequential) encoding
- Encodes the pictures in the chrominance sampling format of YCbCr4:2:0 and YCbCr4:2:2
- Supports multiple input picture formats:
  - Semi-planar YCbCr4:2:0
  - Semi-planar YCbCr4:2:2
- Supports JPEG encoding with the performance of 1080p@60fps
- Supports configurable picture resolutions
  - Minimum picture resolution: 192 x 96
  - Maximum picture resolution: 4096 x 4096
- Supports the picture width or height step of 8
- Supports configurable quantization tables for the Y component, Cb component and Cr component respectively
- Supports OSD front-end overlapping
  - OSD overlaying before encoding for a maximum of 16 regions
  - OSD overlaying with any size and at any position (within the size and position range of the picture)
  - 16-level alpha blending
  - OSD overlaying control (enabled or disabled)
- Supports the color-to-gray function
- Supports the MJPEG output bit rate ranging from 2 kbit/s to 60 Mbit/s

### 4.4.2.2. Block Diagram

The functional block diagram of the JPGE is as follows.



Figure 4- 4. JPGE Block Diagram

The JPGE realizes various protocol processing with large computation such as OSD, level shift, DCT, quantization, scanning, VLC encoding, and stream generation. The ARM software completes the encoding control processing such as quantization table configuration and interrupt processing.

Before the JPGE starts encoding, the software allocates two types of buffers mainly in the external DDR SDRAM:

- **Input picture buffer**

The JPGE reads the source pictures to be encoded from this buffer during encoding. This buffer is generally written by the Video Input Port module.

- **Stream buffer**

This buffer stores encoded streams. The JPGE writes streams to this buffer during encoding. This buffer is read by software.

## Contents

|                                                     |     |
|-----------------------------------------------------|-----|
| Chapter 5 Memory.....                               | 323 |
| 5.1. SDRAM Controller(DRAMC) .....                  | 323 |
| 5.1.1. Overview .....                               | 323 |
| 5.2. Nand Flash Controller(NDFC) .....              | 324 |
| 5.2.1. Overview .....                               | 324 |
| 5.2.2. Block Diagram .....                          | 324 |
| 5.2.3. Operations and Functional Descriptions ..... | 325 |
| 5.2.4. Programming Guidelines.....                  | 334 |
| 5.2.5. Register List .....                          | 336 |
| 5.2.6. Register Description .....                   | 337 |
| 5.3. SD/MMC Host Controller(SMHC) .....             | 367 |
| 5.3.1. Overview .....                               | 367 |
| 5.3.2. Block Diagram .....                          | 367 |
| 5.3.3. Operations and Functional Descriptions ..... | 368 |
| 5.3.4. Programming Guidelines.....                  | 372 |
| 5.3.5. Register List .....                          | 375 |
| 5.3.6. Register Description .....                   | 377 |

## Figures

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Figure 5- 1. NDFC Block Diagram .....                             | 325 |
| Figure 5- 2. Conventional Serial Access Cycle Diagram (SAM0)..... | 327 |
| Figure 5- 3. EDO Type Serial Access after Read Cycle (SAM1) ..... | 327 |
| Figure 5- 4. Extending EDO Type Serial Access Mode (SAM2).....    | 327 |
| Figure 5- 5. Command Latch Cycle.....                             | 328 |
| Figure 5- 6. Address Latch Cycle .....                            | 328 |
| Figure 5- 7. Write Data to Flash Cycle.....                       | 328 |
| Figure 5- 8. Waiting R/B# Ready Diagram.....                      | 329 |
| Figure 5- 9. WE# High to RE# Low Timing Diagram.....              | 329 |
| Figure 5- 10. RE# High to WE# Low Timing Diagram .....            | 329 |
| Figure 5- 11. Address to Data Loading Timing Diagram.....         | 330 |
| Figure 5- 12. Page Read Command Diagram .....                     | 331 |
| Figure 5- 13. Page Program Diagram .....                          | 331 |
| Figure 5- 14. EF-NAND Page Read Diagram .....                     | 332 |
| Figure 5- 15. Interleave Page Read Diagram.....                   | 332 |
| Figure 5- 16. Internal DMA Descriptor Chain Structure.....        | 333 |
| Figure 5- 17. SMHC Block Diagram .....                            | 368 |
| Figure 5- 18. IDMAC Descriptor Structure Diagram.....             | 369 |

## Tables

|                                        |     |
|----------------------------------------|-----|
| Table 5- 1. NDFC External Signals..... | 325 |
| Table 5- 2. NDFC Clock Sources.....    | 326 |
| Table 5- 3. SMHC External Signals..... | 368 |
| Table 5- 4. SMHC Clock Sources.....    | 369 |

Confidential

# Chapter 5 Memory

## 5.1. SDRAM Controller (DRAMC)

### 5.1.1. Overview

The SDRAM Controller (DRAMC) provides a simple, flexible, burst-optimized interface to all industry-standard DDR4/DDR3/DDR3L and Low Power DDR3/4 SDRAM. It supports up to a 32 Gbits memory address space.

The DRAMC automatically handles memory management, initialization, and refresh operations. It gives the host CPU a simple command interface, hiding details of the required address, page, and burst handling procedures. All memory parameters are runtime-configurable, including timing, memory setting, SDRAM type, and Extended-Mode-Register settings.

The SDRAM includes the following features:

- Supports 32-bit one channel
- Supports 2 chip select signals
- Supports DDR4/DDR3/DDR3L/LPDDR3/LPDDR4 SDRAM
- Supports the power voltage of different memory device: 1.2 V, 1.5 V, 1.35 V and 1.1 V
- Supports clock frequency up to 792 MHz for DDR4
- Supports clock frequency up to 792 MHz for DDR3/DDR3L
- Supports clock frequency up to 792 MHz for LPDDR3
- Supports clock frequency up to 792 MHz for LPDDR4
- Supports memory capacity up to 32 Gbits (4 GB)
- Automatically generates initialization and refresh sequences
- Runtime-configurable parameters setting for application flexibility
- Priority of transferring through multiple ports is programmable
- Random read or write operation is supported

## 5.2. Nand Flash Controller (NDFC)

### 5.2.1. Overview

The NDFC is the NAND Flash Controller which supports all NAND flash memory available in the market. New type flash can be supported by software re-configuration.

The On-the-fly error correction code (ECC) is built-in NDFC for enhancing reliability. BCH is implemented and it can detect and correct up to 80 bits error per 1024 bytes data. The on chip ECC and parity checking circuit of NDFC frees CPU for other tasks. The ECC function can be disabled by software.

The data can be transferred by DMA or by CPU memory-mapped IO method. The NDFC provides automatic timing control for reading or writing external Flash. The NDFC maintains the proper relativity for CLE, CE# and ALE control signal lines. There are three different kinds of modes for serial read access, mode0 is for conventional serial access , mode1 is for EDO type and the mode2 is for extension EDO type. NDFC can monitor the status of R/B# signal line.

Block management and wear leveling management are implemented in software.

The NDFC has the following features:

- Supports all SLC/MLC/TLC flash and EF-NAND memory available in the market
- Configure randomize seed by using software
- Software configure method for various system and memory types
- Supports 2 chip selects, and 2 ready\_busy signals
- Up to 8-bit data bus width
- Supports 1024, 2048, 4096, 8192, 16384, 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 corrected error
- ECC automatic disable function for all 0xff data
- NDFC status information is reported by its registers, and interrupt is supported
- One Command FIFO
- Internal DMA controller based on chain-structured descriptor list
- 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, and 100 MHz in both DDR1.0 and DDR2.0 mode
- Self-debug for NDFC debug

### 5.2.2. Block Diagram

The block diagram of the NDFC is shown as follows.



Figure 5- 1. NDFC Block Diagram

### 5.2.3. Operations and Functional Descriptions

#### 5.2.3.1. External Signals

Table 5-1 describes the external signals of NDFC. DQ0~DQ7 and DQS are bidirectional I/O. WE,ALE,CLE,CE,RE are output pin, RB is input pin. The RB pin in the NAND device is an open-drain driver, which must need a pull-up resistor.

Table 5- 1. NDFC External Signals

| Signal   | Description                          | Type |
|----------|--------------------------------------|------|
| NAND_WE  | Write enable                         | O    |
| NAND_RE  | Read enable                          | O    |
| NAND_ALE | Address latch enable, high is active | O    |
| NAND_CLE | Command latch enable, high is active | O    |
| NAND_CE0 | Chip enable, low is active           | O    |
| NAND_CE1 | Chip enable, low is active           | O    |

|          |                           |     |
|----------|---------------------------|-----|
| NAND_RB0 | Ready/busy, low is active | I   |
| NAND_RB1 | Ready/busy, low is active | I   |
| NAND_DQ0 | Data input / output       | I/O |
| NAND_DQ1 | Data input / output       | I/O |
| NAND_DQ2 | Data input / output       | I/O |
| NAND_DQ3 | Data input / output       | I/O |
| NAND_DQ4 | Data input / output       | I/O |
| NAND_DQ5 | Data input / output       | I/O |
| NAND_DQ6 | Data input / output       | I/O |
| NAND_DQ7 | Data input / output       | I/O |
| NAND_DQS | Data strobe               | I/O |

### 5.2.3.2. Clock Sources

To ensure ECC efficiency, ECC engine and NDFC internal logic use different clock. The clock of NDFC internal logic is set by **NAND\_0 Clock Register**, the clock of ECC engine is set by **NAND\_1 Clock Register**. Note that **NAND\_0 Clock Register** set the internal logic clock of NDFC, but the frequency of external Nand Flash device is half of NDFC internal logic clock. That is, if external Nand Flash runs at 40 MHz, then NDFC need set to 80 MHz.

Both ECC engine and NDFC internal logic have five different clock sources. Users can select one of them to make ECC engine or internal logic clock source. Table 5-2 describes the clock sources of NDFC. Users can see CCU in chapter 3.3 for clock setting, configuration and gating information.

Table 5- 2. NDFC Clock Sources

| Clock Sources   | Description                                |
|-----------------|--------------------------------------------|
| OSC24M          | 24 MHz Crystal                             |
| PLL_PERIPH0(1X) | Peripheral Clock, default value is 600 MHz |
| PLL_PERIPH1(1X) | Peripheral Clock, default value is 600 MHz |
| PLL_PERIPH0(2X) | Peripheral Clock, default value is 1.2 GHz |
| PLL_PERIPH1(2X) | Peripheral Clock, default value is 1.2 GHz |

### 5.2.3.3. Timing Diagram

Typically, there are two kinds of serial access methods. One method is conventional method which fetching data at the rise edge of NDFC\_RE# signal line. Another one is EDO type which fetching data at the next fall edge of NDFC\_RE# signal line.



Figure 5- 2. Conventional Serial Access Cycle Diagram (SAM0)



Figure 5- 3. EDO Type Serial Access after Read Cycle (SAM1)



Figure 5- 4. Extending EDO Type Serial Access Mode (SAM2)



Figure 5- 5. Command Latch Cycle



Figure 5- 6. Address Latch Cycle



Figure 5- 7. Write Data to Flash Cycle



Figure 5- 8. Waiting R/B# Ready Diagram



Figure 5- 9. WE# High to RE# Low Timing Diagram



Figure 5- 10. RE# High to WE# Low Timing Diagram



**Figure 5- 11. Address to Data Loading Timing Diagram**

#### Timing cycle list:

| ID  | Parameter                     | Timing(ns)           | Notes                                                    |
|-----|-------------------------------|----------------------|----------------------------------------------------------|
| t1  | NDFC_CLE setup time           | 2T                   |                                                          |
| t2  | NDFC_CLE hold time            | 2T                   |                                                          |
| t3  | NDFC_CE setup time            | 2T                   |                                                          |
| t4  | NDFC_CE hold time             | 2T                   |                                                          |
| t5  | NDFC_WE# pulse width          | T <sup>(1)</sup>     |                                                          |
| t6  | NDFC_WE# hold time            | T                    |                                                          |
| t7  | NDFC_ALE setup time           | 2T                   |                                                          |
| t8  | Data setup time               | T                    |                                                          |
| t9  | Data hold time                | T                    |                                                          |
| t10 | Ready to NDFC_RE# low         | 3T                   |                                                          |
| t11 | NDFC_ALE hold time            | 2T                   |                                                          |
| t12 | NDFC_RE# pulse width          | T                    |                                                          |
| t13 | NDFC_RE# hold time            | T                    |                                                          |
| t14 | Read cycle time               | 2T                   |                                                          |
| t15 | Write cycle time              | 2T                   |                                                          |
| t16 | NDFC_WE# high to R/B# busy    | T_WB <sup>(2)</sup>  | Specified by timing configure register (NDFC_TIMING_CFG) |
| t17 | NDFC_WE# high to NDFC_RE# low | T_WHR <sup>(3)</sup> | Specified by timing configure register (NDFC_TIMING_CFG) |
| t18 | NDFC_RE# high to NDFC_WE# low | T_RHW <sup>(4)</sup> | Specified by timing configure register (NDFC_TIMING_CFG) |
| t19 | Address to Data Loading time  | T_AdL <sup>(5)</sup> | Specified by timing configure register (NDFC_TIMING_CFG) |

**Note(1):** T is the cycle of the internal clock.

**Note(2),(3),(4),(5):** These values are configurable in nand flash controller. The value of T\_WB could be 14\*2T/22\*2T/30\*2T/38\*2T, the value of T\_WHR could be 0\*2T/6\*2T/14\*2T/22\*2T, the value of T\_RHW could be 4\*2T/12\*2T/20\*2T/28\*2T, the value of T\_AdL could be 0\*2T/6\*2T/14\*2T/22\*2T.



Figure 5-12. Page Read Command Diagram



Figure 5-13. Page Program Diagram



Figure 5-14. EF-NAND Page Read Diagram



Figure 5-15. Interleave Page Read Diagram

#### 5.2.3.4. Internal DMA Controller Descriptors

##### 5.2.3.4.1. Descriptor Structure

The internal DMA controller of the NDFC can transfer data between DMA FIFO in NDFC and DMA buffer in host memory using DMA descriptors. DMA descriptors in the host memory with chain structure is shown in Figure 5-16.



**Figure 5- 16. Internal DMA Descriptor Chain Structure**

The start address of DMA descriptor list must be word (32-bit) aligned, and will be configured to **NDFC DMA Descriptor List Base Address Register**. Each DMA descriptor consists of four words(32-bit).

#### **5.2.3.4.2. Descriptor Definition**

| Config |                                                                                                                                          |
|--------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | Description                                                                                                                              |
| 31:4   | /                                                                                                                                        |
| 3      | FIRST_FLAG<br>When set, this bit indicates that this descriptor contains the first buffer of data. Must be set to 1 in first descriptor. |
| 2      | LAST_FLAG<br>When set, this bit indicates that the buffers pointed by this descriptor are the last data buffer.                          |
| 1:0    | /                                                                                                                                        |

| Size  |                                                                                                                                                                                       |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Description                                                                                                                                                                           |
| 31:16 | /                                                                                                                                                                                     |
| 15:0  | BUFF_SIZE<br>These bits indicate the data buffer byte size, which must be a multiple of 8 bytes. If this field is 0, the DMA ignores this buffer and proceeds to the next descriptor. |

| Buff Addr |                                                                                                                                      |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Description                                                                                                                          |
| 31:0      | BUFF_ADDR<br>These bits indicate the physical address of DMA data buffer in host memory. The buffer address must be 4 bytes aligned. |

| <b>Next Description</b> |                                                                                                                         |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------|
| <b>Bit</b>              | <b>Description</b>                                                                                                      |
| 31:0                    | <b>NEXT_DESC_ADDR</b><br>These bits indicate the pointer to the physical host memory of the next descriptor is present. |

### 5.2.3.5. NDFC Data Block Mask Register

ECC\_DATA\_BLOCK is written or read through the value of **NDFC Data Block Mask Register**. But in real application scenario, capacity could not waste, so writing operation usually does not use the function, only reading operation uses. In reading operation, we divides Sequence mode and Interleave mode through the store position of user\_data.

**Sequence mode:** The user\_data of every 1K main area data and ECC encoder data are next to the main area data.

**Interleave mode:** All user\_data and ECC encoder data are stored from page\_size position.

When any **ECC\_DATA\_BLOCK** within page is read through batch command(**NDFC\_CMD\_TYPE** in 0x24 register is 0x10), the register is used differently for Sequence mode and Interleave mode.

Sequence mode can only support continue **ECC\_DATA\_BLOCK**, the register value can only be 0x1,0x3,0x7,etc. But Interleave mode has not limit.

Whether Sequence mode or Interleave mode, the first reading **ECC\_DATA\_BLOCK** is used to calculate corresponding column address, and column address is written to 0x14 and 0x18 register.

### 5.2.3.6. NDFC Enhanced Feature Register

The bit[24] and bit[23:16] of the register are used to judge whether free space need be padded random data except valid data when batch command function is used.

Take a SanDisk chip(SDTNQGAMA-008G) as an example:

Refer to the specification of the SanDisk chip, the page\_size of the SanDisk chip is (16384+1280) bytes, but BCH level uses 40bit/1K, if user\_data is 32 bytes, then the used space is 1152 bytes(14\*40/8\*16+32), the 128 bytes (1280-1152) space is not written. If there need be filled with 1 page, then the bit[24] of the register can be set to 1, and the bit[23:16] is written to 0x80, that the controller can automatically pad 128 bytes random data.



#### NOTE

Make sure that random function is enabled if there need be sent random data, that is, the **NDFC\_RANDOM\_EN** of 0x34 register is 0x1, or else the padding data is non-random, is all-0.

## 5.2.4. Programming Guidelines

### 5.2.4.1. Initializing Nand Flash

The NAND Flash is initialized as follows:

Step1: Read **NDFC\_ST**[NDFC\_RB\_STATE0] to wait flash in the idle status.

Step2: Configure **NDFC\_CMD**[NDFC\_SEND\_FIRST\_CMD] to 1 to send the first command, configure **NDFC\_CMD**[NDFC\_WAIT\_FLAG] to 1 to set wait RB; write 0xFF to **NDFC\_CMD**[NDFC\_CMD\_LOW\_BYTE] to send reset command.

Step3: Read **NDFC\_ST**[NDFC\_CMD\_INT\_FLAG] to wait transfer command end interrupt flag pending, after pending,

write 1 to clear the flag.

#### 5.2.4.2. Erasing Nand Flash

The NAND Flash is erased as follows:

Step1: Read **NDFC\_ST[NDFC\_RB\_STATE0]** to wait flash in the idle status.

Step2: Configure **NDFC\_CMD[NDFC\_SEND\_FIRST\_CMD]** to 1 to send the first command, configure **NDFC\_CMD[NDFC\_WAIT\_FLAG]** to 1 to set wait RB;

Configure **NDFC\_CMD[NDFC\_SEND\_ADDR]** to 1 to enable transfer address, configure **NDFC\_CMD[NDFC\_ADR\_NUM]** to set the number of address to be transferred;

Write the address of the block to be erased in **NDFC\_ADDR\_LOW** and **NDFC\_ADDR\_HIGH**;

Set **NDFC\_CMD[NDFC\_CMD\_LOW\_BYTE]** to 0x60 to send block erase command.

Step3: Read **NDFC\_ST[NDFC\_CMD\_INT\_FLAG]** to wait *transfer command end interrupt flag* pending, after pending, write 1 to clear the flag.

Step4: Read **NDFC\_ST[NDFC\_RB\_STATE0]** to wait flash in the idle status.

Step5: Set **NDFC\_CMD[NDFC\_WAIT\_FLAG]** to 1 to ensure wait RB, set **NDFC\_CMD[NDFC\_SEND\_FIRST\_CMD]** to 1 to send the first command; set **NDFC\_CMD[NDFC\_CMD\_LOW\_BYTE]** to 0xD0 to send erasing command.

Step6: Read **NDFC\_ST[NDFC\_CMD\_INT\_FLAG]** to wait *transfer command end interrupt flag* pending, after pending, write 1 to clear the flag.

Step7: Read flash state until flash is ready, configure **NDFC\_CNT[NDFC\_DATA\_CNT]** to set 1byte transfer data, set **NDFC\_CMD[NDFC\_SEND\_FIRST\_CMD, NDFC\_DATA\_TRANS]** to 0x3 to send the first command and transfer data.

Set **NDFC\_CMD[NDFC\_CMD\_LOW\_BYTE]** to 0x70 to send read status command, read **RAM0\_BASE** to wait ready status.

#### 5.2.4.3. Writing Nand Flash

Step1: Erase the address of the block to be operated.

Step2: Read **NDFC\_ST[NDFC\_RB\_STATE0]** to wait flash in the idle status.

Step3: Configure **RAM0\_BASE** to write data to RAM0.

Step4: Configure **NDFC\_CNT[NDFC\_DATA\_CNT]** to set transferred data;

Set **NDFC\_CMD[NDFC\_SEND\_FIRST\_CMD]** to 1 to send the first command, configure **NDFC\_CMD[NDFC\_DATA\_TRANS, NDFC\_ACCESS\_DIR]** to 0x3 to set access direction as writing;

Set **NDFC\_CMD[NDFC\_SEND\_ADDR]** to 1 to enable transfer address, configure **NDFC\_CMD[NDFC\_ADR\_NUM]** to set the number of the address to be transferred, write the address of the block to be operated in **NDFC\_ADDR\_LOW** and **NDFC\_ADDR\_HIGH**;

Set **NDFC\_CMD[NDFC\_CMD\_LOW\_BYTE]** to 0x80 to send page program command.

Step5: Read **NDFC\_ST[NDFC\_RB\_STATE0]** to wait flash in the idle status.

Step6: Configure **NDFC\_CMD[NDFC\_SEND\_FIRST\_CMD]** to 1 to send the first command, configure **NDFC\_CMD[NDFC\_WAIT\_FLAG]** to 1 to set wait RB; configure **NDFC\_CMD[NDFC\_CMD\_LOW\_BYTE]** to 0x10 to send end command.

Step7: Read **NDFC\_ST[NDFC\_CMD\_INT\_FLAG]** to wait *transfer command end interrupt flag* pending, after pending, write 1 to clear the flag.

#### 5.2.4.4. Reading Nand Flash

Step1: Read [NDFC\\_ST\[NDFC\\_RB\\_STATE0\]](#) to wait flash in the idle status.

Step2: Configure [NDFC\\_CNT\[NDFC\\_DATA\\_CNT\]](#) to set transferred data;

Configure [NDFC\\_CMD\[NDFC\\_SEND\\_FIRST\\_CMD\]](#) to 1 to send the first command;

Configure [NDFC\\_CMD\[NDFC\\_ACCESS\\_DIR\]](#) to 0 to set access direction as reading;

Set [NDFC\\_CMD\[NDFC\\_SEND\\_ADDR\]](#) to 1 to enable transfer address, configure [NDFC\\_CMD\[NDFC\\_ADR\\_NUM\]](#) to set the number of the address to be transferred, write the address of the block to be operated in [NDFC\\_ADDR\\_LOW](#) and [NDFC\\_ADDR\\_HIGH](#);

Set [NDFC\\_CMD\[NDFC\\_CMD\\_LOW\\_BYTE\]](#) to 0x00 to send page read command.

Step3: Read [NDFC\\_ST\[NDFC\\_RB\\_STATE0\]](#) to wait flash in the idle status.

Step4: Configure [NDFC\\_CMD\[NDFC\\_SEND\\_FIRST\\_CMD\]](#) to 1 to send the first command, configure [NDFC\\_CMD\[NDFC\\_WAIT\\_FLAG\]](#) to 1 to set wait RB; configure [NDFC\\_CMD\[NDFC\\_CMD\\_LOW\\_BYTE\]](#) to 0x30 to send end command.

Step5: Read [RAM0\\_BASE](#) to get data from flash.

Step6: Read [NDFC\\_ST\[NDFC\\_CMD\\_INT\\_FLAG\]](#) to wait *transfer command end interrupt flag* pending, after pending, write 1 to clear the flag.

#### 5.2.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| NDFC        | 0x04011000   |

| Register Name        | Offset | Description                                         |
|----------------------|--------|-----------------------------------------------------|
| NDFC_CTL             | 0x0000 | NDFC Configure and Control Register                 |
| NDFC_ST              | 0x0004 | NDFC Status Information Register                    |
| NDFC_INT             | 0x0008 | NDFC Interrupt Control Register                     |
| NDFC_TIMING_CTL      | 0x000C | NDFC Timing Control Register                        |
| NDFC_TIMING_CFG      | 0x0010 | NDFC Timing Configure Register                      |
| NDFC_ADDR_LOW        | 0x0014 | NDFC Low Word Address Register                      |
| NDFC_ADDR_HIGH       | 0x0018 | NDFC High Word Address Register                     |
| NDFC_DATA_BLOCK_MASK | 0x001C | NDFC Data Block Mask Register                       |
| NDFC_CNT             | 0x0020 | NDFC Data Counter Register                          |
| NDFC_CMD             | 0x0024 | NDFC Commands IO Register                           |
| NDFC_RCMD_SET        | 0x0028 | Read Command Set Register for Vendor's NAND Memory  |
| NDFC_WCMD_SET        | 0x002C | Write Command Set Register for Vendor's NAND Memory |
| NDFC_ECC_CTL         | 0x0034 | NDFC ECC Control Register                           |
| NDFC_ECC_ST          | 0x0038 | NDFC ECC Status Register                            |
| NDFC_DATA_PAT_STA    | 0x003C | NDFC Data Pattern Status Register                   |
| NDFC_EFR             | 0x0040 | NDFC Enhanced Feature Register                      |

|                         |               |                                                     |
|-------------------------|---------------|-----------------------------------------------------|
| NDFC_RDATA_STA_CTL      | 0x0044        | NDFC Read Data Status Control Register              |
| NDFC_RDATA_STA_0        | 0x0048        | NDFC Read Data Status Register 0                    |
| NDFC_RDATA_STA_1        | 0x004C        | NDFC Read Data Status Register 1                    |
| NDFC_ERR_CNT_N          | 0x0050+0x04*N | NDFC Error Counter Register(N from 0 to 7)          |
| NDFC_USER_DATA_LEN_N    | 0x0070+0x04*N | NDFC User Data Length Register(N from 0 to 3)       |
| NDFC_USER_DATA_N        | 0x0080+0x04*N | NDFC User Data Field Register N (N from 0 to 31)    |
| NDFC_EFNAND_STA         | 0x0110        | NDFC EFNAND Status Register                         |
| NDFC_SPARE_AREA         | 0x0114        | NDFC Spare Area Register                            |
| NDFC_PAT_ID             | 0x0118        | NDFC Pattern ID Register                            |
| NDFC_DDR2_SPEC_CTL      | 0x011C        | NDFC DDR2 Specific Control Register                 |
| NDFC_NDMA_MODE_CTL      | 0x0120        | NDFC Normal DMA Mode Control Register               |
| NDFC_MDMA_DLBA_REG      | 0x0200        | NDFC MBUS DMA Descriptor List Base Address Register |
| NDFC_MDMA_STA           | 0x0204        | NDFC MBUS DMA Interrupt Status Register             |
| NDFC_DMA_INT_MASK       | 0x0208        | NDFC MBUS DMA Interrupt Enable Register             |
| NDFC_MDMA_CUR_DESC_ADDR | 0x020C        | NDFC MBUS DMA Current Descriptor Address Register   |
| NDFC_MDMA_CUR_BUF_ADDR  | 0x0210        | NDFC MBUS DMA Current Buffer Address Register       |
| NDFC_DMA_CNT            | 0x0214        | NDFC DMA Byte Counter Register                      |
| NDFC_IO_DATA            | 0x0300        | NDFC Input/Output Data Register                     |

## 5.2.6. Register Description

### 5.2.6.1. 0x0000 NDFC Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: NDFC_CTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28             | R/W        | 0x0         | <p>NDFC_DDR_TYPE<br/>                     Type of DDR data interface<br/>                     This bit is valid when NF_TYPE is 0x2 or 0x3.<br/>                     0: DDR<br/>                     1: DDR2</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 27:24          | R/W        | 0x0         | <p>NDFC_CE_SEL<br/>                     Chip Select for NAND Flash Chips<br/>                     0000: NDFC Select Chip 0<br/>                     0001: NDFC Select Chip 1<br/>                     0010: NDFC Select Chip 2<br/>                     0011: NDFC Select Chip 3<br/>                     0100: NDFC Select Chip 4<br/>                     0101: NDFC Select Chip 5<br/>                     0110: NDFC Select Chip 6<br/>                     0111: NDFC Select Chip 7<br/>                     1000: NDFC Select Chip 8<br/>                     1001: NDFC Select Chip 9</p> |

|       |     |     |                                                                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1010: NDFC Select Chip 10<br>1011: NDFC Select Chip 11<br>1100: NDFC Select Chip 12<br>1101: NDFC Select Chip 13<br>1110: NDFC Select Chip 14<br>1111: NDFC Select Chip 15 |
| 23:22 | /   | /   | /                                                                                                                                                                          |
| 21    | R/W | 0x0 | NDFC_DDR_RM<br>DDR Repeat Data Mode<br>0: Lower byte<br>1: Higher byte                                                                                                     |
| 20    | R/W | 0x0 | NDFC_DDR_REN<br>DDR Repeat Enable<br>0: Disable<br>1: Enable                                                                                                               |
| 19:18 | R/W | 0x0 | NF_TYPE<br>NAND Flash Type<br>00: Normal SDR NAND<br>01: Reserved<br>10: ONFI DDR NAND<br>11: Toggle DDR NAND                                                              |
| 17    | R/W | 0x0 | NDFC_CLE_POL<br>NDFC Command Latch Enable (CLE) Signal Polarity Select<br>0: High active<br>1: Low active                                                                  |
| 16    | R/W | 0x0 | NDFC_ALE_POL<br>NDFC Address Latch Enable (ALE) Signal Polarity Select<br>0: High active<br>1: Low active                                                                  |
| 15    | R/W | 0x0 | NDFC_DMA_TYPE<br>0: Dedicated DMA<br>1: Normal DMA                                                                                                                         |
| 14    | R/W | 0x0 | NDFC_RAM_METHOD<br>Access internal RAM method<br>0: Access internal RAM by AHB method<br>1: Access internal RAM by DMA method                                              |
| 13:12 | /   | /   | /                                                                                                                                                                          |
| 11:8  | R/W | 0x0 | NDFC_PAGE_SIZE<br>000: 1KB<br>001: 2KB<br>010: 4KB<br>011: 8KB<br>100: 16KB<br>101: 32KB<br>The page size is for main field data.                                          |

|     |       |     |                                                                                                                                                                                                                                                                                                                                        |
|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | /     | /   | /                                                                                                                                                                                                                                                                                                                                      |
| 6   | R/W   | 0x0 | <p>NDFC_CE_ACT<br/>Chip Select Signal CE# Control during NAND Operation<br/>0: De-active Chip Select Signal NDFC_CE# during data loading, serial access and other no operation stage for power consumption. NDFC automatic controls Chip Select Signals.<br/>1: Chip select signal NDFC_CE# is always active after NDFC is enabled</p> |
| 5   | /     | /   | /                                                                                                                                                                                                                                                                                                                                      |
| 4:3 | R/W   | 0x0 | <p>NDFC_RB_SEL<br/>NDFC External R/B Signal Select<br/>The value 0-3 selects the external R/B signal. The same R/B signal can be used for multiple chip select flash.</p>                                                                                                                                                              |
| 2   | R/W   | 0x0 | <p>NDFC_BUS_WIDTH<br/>0: 8-bit bus<br/>1: 16-bit bus</p>                                                                                                                                                                                                                                                                               |
| 1   | R/W1C | 0x0 | <p>NDFC_RESET<br/>NDFC Reset<br/>Write 1 to reset NDFC and clear to 0 after reset</p>                                                                                                                                                                                                                                                  |
| 0   | R/W   | 0x0 | <p>NDFC_EN<br/>NDFC Enable Control<br/>0: Disable NDFC<br/>1: Enable NDFC</p>                                                                                                                                                                                                                                                          |

#### 5.2.6.2. 0x0004 NDFC Status Register (Default Value: 0x0000\_0F00)

| Offset: 0x0004 |            |             | Register Name: NDFC_ST                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                 |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                           |
| 13             | R          | 0x0         | <p>NDFC_RDATA_STA_0<br/>0: The number of bit 1 during current read operation is more than threshold value.<br/>1: The number of bit 1 during current read operation is less than or equal to threshold value.<br/>This field only is valid when NDFC_RDATA_STA_EN is 1.<br/>The threshold value is configured in NDFC_RDATA_STA_TH.</p>     |
| 12             | R          | 0x0         | <p>NDFC_RDATA_STA_1<br/>0: The number of bit 0 during current read operation is more than threshold value.<br/>1: The number of bit 0 during current read operation is less than or equal to the threshold value.<br/>This field only is valid when NDFC_RDATA_STA_EN is 1.<br/>The threshold value is configured in NDFC_RDATA_STA_TH.</p> |
| 11             | R          | 0x1         | NDFC_RB_STATE3<br>NAND Flash R/B 3 Line State                                                                                                                                                                                                                                                                                               |

|     |       |     |                                                                                                                                                                                                                                                                                  |
|-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |     | 0: NAND Flash in BUSY State<br>1: NAND Flash in READY State                                                                                                                                                                                                                      |
| 10  | R     | 0x1 | NDFC_RB_STATE2<br>NAND Flash R/B 2 Line State<br>0: NAND Flash in BUSY State<br>1: NAND Flash in READY State                                                                                                                                                                     |
| 9   | R     | 0x1 | NDFC_RB_STATE1<br>NAND Flash R/B 1 Line State<br>0: NAND Flash in BUSY State<br>1: NAND Flash in READY State                                                                                                                                                                     |
| 8   | R     | 0x1 | NDFC_RB_STATE0<br>NAND Flash R/B 0 Line State<br>0: NAND Flash in BUSY State<br>1: NAND Flash in READY State                                                                                                                                                                     |
| 7:5 | /     | /   | /                                                                                                                                                                                                                                                                                |
| 4   | R     | 0x0 | NDFC_STA<br>0: NDFC FSM in IDLE state<br>1: NDFC FSM in BUSY state<br>When NDFC_STA is 0, NDFC can accept new command and process command.                                                                                                                                       |
| 3   | R     | 0x0 | NDFC_CMD_FIFO_STATUS<br>0: Command FIFO not full and can receive new command<br>1: Full and waiting NDFC to process commands in FIFO<br>Since there is only one 32-bit FIFO for command. When NDFC latches one command, command FIFO is free and can accept another new command. |
| 2   | R/W1C | 0x0 | NDFC_DMA_INT_FLAG<br>When it is 1, it means that a pending DMA is completed. It will be cleared after writing 1 to this bit or it will be automatically cleared before FSM processing an new command.                                                                            |
| 1   | R/W1C | 0x0 | NDFC_CMD_INT_FLAG<br>When it is 1, it means that NDFC has finished one Normal Command Mode or one Batch Command Work Mode. It will be cleared after writing 1 to this bit or it will be automatically cleared before FSM processing an new command.                              |
| 0   | R/W1C | 0x0 | NDFC_RB_B2R<br>When it is 1, it means that NDFC_R/B# signal is transferred from BUSY state to READY state. It will be cleared after writing 1 to this bit.                                                                                                                       |

### 5.2.6.3. 0x0008 NDFC Interrupt and DMA Enable Register(Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: NDFC_INT                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:3           | /          | /           | /                                                                                   |
| 2              | R/W        | 0x0         | NDFC_DMA_INT_ENABLE<br>Enable or disable interrupt when a pending DMA is completed. |

|   |     |     |                                                                                                                                                                                                            |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | R/W | 0x0 | <b>NDFC_CMD_INT_ENABLE</b><br>Enable or disable interrupt when NDFC has finished the procession of a single command in normal command work mode or one batch command work mode.<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | <b>NDFC_B2R_INT_ENABLE</b><br>Enable or disable interrupt when NDFC_RB# signal is transferring from BUSY state to READY state.<br>0: Disable<br>1: Enable                                                  |

#### 5.2.6.4. 0x000C NDFC Timing Control Register(Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: NDFC_TIMING_CTL                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                 |
| 31:12          | /          | /           | /                                                                                                                                                                                                                           |
| 11:8           | R/W        | 0x0         | <b>NDFC_READ_PIPE</b><br>In SDR mode:<br>00: Normal<br>01: EDO<br>10: E-EDO<br>Others: Reserved<br><br>In DDR mode:<br>1~15 is valid.(These bits configure the number of clock when data is valid after RE#'s falling edge) |
| 7:6            | /          | /           | /                                                                                                                                                                                                                           |
| 5:0            | R/W        | 0x0         | <b>NDFC_DC_CTL</b><br>NDFC Delay Chain Control.<br>These bits are only valid in DDR data interface, and configure the relative phase between DQS and DQ[0...7] .                                                            |

#### 5.2.6.5. 0x0010 NDFC Timing Configure Register(Default Value: 0x0000\_0095)

| Offset: 0x0010 |            |             | Register Name: NDFC_TIMING_CFG                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:20          | /          | /           | /                                                                               |
| 19:18          | R/W        | 0x0         | <b>T_WC</b><br>Write Cycle Time<br>00: 1*2T<br>01: 2*2T<br>10: 3*2T<br>11: 4*2T |

|       |     |     |                                                                                                                                           |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | R/W | 0x0 | T_CCS<br>Change Column Setup Time<br>00: 12*2T<br>01: 20*2T<br>10: 28*2T<br>11: 60*2T                                                     |
| 15:14 | R/W | 0x0 | T_CLHZ<br>CLE High to Output Hi-z<br>00: 2*2T<br>01: 8*2T<br>10: 16*2T<br>11: 31*2T                                                       |
| 13:12 | R/W | 0x0 | T_CS<br>CE Setup Time<br>00: 2*2T<br>01: 8*2T<br>10: 16*2T<br>11: 31*2T                                                                   |
| 11    | R/W | 0x0 | T_CDQSS<br>DQS Setup Time for Data Input Start<br>0: 4*2T<br>1: 20*2T                                                                     |
| 10:8  | R/W | 0x0 | T_CAD<br>Command, Address, Data Delay<br>000: 2*2T<br>001: 6*2T<br>010: 10*2T<br>011: 14*2T<br>100: 22*2T<br>101: 30*2T<br>110/111: 62*2T |
| 7:6   | R/W | 0x2 | T_RHW<br>Cycle Number from RE# High to WE# Low<br>00: 4*2T<br>01: 12*2T<br>10: 20*2T<br>11: 28*2T                                         |
| 5:4   | R/W | 0x1 | T_WHR<br>Cycle Number from WE# High to RE# Low<br>00: 0*2T<br>01: 6*2T<br>10: 14*2T<br>11: 22*2T                                          |
| 3:2   | R/W | 0x1 | T_ADL<br>Cycle Number from Address to Data Loading                                                                                        |

|     |     |     |                                                                                               |
|-----|-----|-----|-----------------------------------------------------------------------------------------------|
|     |     |     | 00: 0*2T<br>01: 6*2T<br>10: 14*2T<br>11: 22*2T                                                |
| 1:0 | R/W | 0x1 | T_WB<br>Cycle Number from WE# High to Busy<br>00:14*2T<br>01: 22*2T<br>10: 30*2T<br>11: 38*2T |

#### 5.2.6.6. 0x0014 NDFC Address Low Word Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: NDFC_ADDR_LOW                    |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:24          | R/W        | 0x0         | ADDR_DATA4<br>NAND Flash 4th Cycle Address Data |
| 23:16          | R/W        | 0x0         | ADDR_DATA3<br>NAND Flash 3rd Cycle Address Data |
| 15:8           | R/W        | 0x0         | ADDR_DATA2<br>NAND Flash 2nd Cycle Address Data |
| 7:0            | R/W        | 0x0         | ADDR_DATA1<br>NAND Flash 1st Cycle Address Data |

#### 5.2.6.7. 0x0018 NDFC Address High Word Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: NDFC_ADDR_HIGH                   |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:24          | R/W        | 0x0         | ADDR_DATA8<br>NAND Flash 8th Cycle Address Data |
| 23:16          | R/W        | 0x0         | ADDR_DATA7<br>NAND Flash 7th Cycle Address Data |
| 15:8           | R/W        | 0x0         | ADDR_DATA6<br>NAND Flash 6th Cycle Address Data |
| 7:0            | R/W        | 0x0         | ADDR_DATA5<br>NAND Flash 5th Cycle Address Data |

#### 5.2.6.8. 0x001C NDFC Data Block Mask Register(Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: NDFC_DATA_BLOCK_MASK |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |

|    |     |     |                                                                                                                                                                                                                                                     |
|----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 31 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 30 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 30 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 29 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 29 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 28 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 28 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 27 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 27 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 26 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 26 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 25 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 25 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 24 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 24 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).                                                                          |

|    |     |     |                                                                                                                                                                                                                                              |
|----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | 0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data.                                                                                                                                                                        |
| 23 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 23 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 22 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 22 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 21 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 21 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 20 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 20 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 19 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 19 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 18 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 18 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 17 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 17 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |

|    |     |     |                                                                                                                                                                                                                                                     |
|----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 16 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 15 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 15 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 14 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 14 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 13 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 13 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 12 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 12 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 11 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 11 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 10 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 10 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 9  | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 9 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).                                                                           |

|   |     |     |                                                                                                                                                                                                                                             |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data.                                                                                                                                                                       |
| 8 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 8 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 7 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 7 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 6 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 6 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 5 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 5 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 4 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 4 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 3 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 3 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 2 | R/W | 0x0 | NDFC_DATA_BLOCK_MASK<br>It is used to indicate the data block 2 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |

|   |     |     |                                                                                                                                                                                                                                                    |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 1 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |
| 0 | R/W | 0x0 | <b>NDFC_DATA_BLOCK_MASK</b><br>It is used to indicate the data block 0 should be written or read during batch command procession(NDFC_CMD_TYPE=0x10 in <b>NDFC_CMD</b> ).<br>0: Disable<br>1: Enable<br>1 data block = 1024 bytes main field data. |

#### 5.2.6.9. 0x0020 NDFC Data Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: NDFC_CNT                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                        |
| 31:10          | /          | /           | /                                                                                                                                                  |
| 9:0            | R/W        | 0x0         | <b>NDFC_DATA_CNT</b><br>Transfer Data Byte Counter<br>The length can be set from 1 byte to 1024 bytes. However, 1024 bytes is set when it is zero. |

#### 5.2.6.10. 0x0024 NDFC Command IO Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: NDFC_CMD                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:30          | R/W        | 0x0         | <b>NDFC_CMD_TYPE</b><br>00: Common command for normal operation<br>01: Special command for Flash spare field operation<br>10: Page command for batch process operation<br>11: Reserved |
| 29             | R/W        | 0x0         | <b>NDFC_SEND_FOURTH_CMD</b><br>0: Donot send fourth set command<br>1: Send it on the external memory's bus<br>It is used for EF-NAND page read.                                        |
| 28             | R/W        | 0x0         | <b>NDFC_SEND_THIRD_CMD</b><br>0: Donot send third set command<br>1: Send it on the external memory's bus<br>It is used for EF-NAND page read.                                          |
| 27             | R/W        | 0x0         | <b>NDFC_SEND_RANDOM_CMD2_CTL</b><br>0: Donot send random cmd2 (NDFC_RANDOM_CMD2)<br>1: Send random cmd2                                                                                |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | <b>Note: It is only valid in batch cmd operation and writing operation.</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 26    | R/W | 0x0 | <p><b>NDFC_DATA_METHOD</b><br/>                     Data swap method when the internal RAM and system memory<br/>                     It is only active for common command and special command.<br/>                     0: No action<br/>                     1: DMA transfer automatically<br/>                     It only is active when NDFC_RAM_METHOD is 1.<br/>                     If this bit is set to 1, NDFC should setup DRQ to fetch data before output to Flash or NDFC should setup DRQ to send to system memory after fetching data from Flash.<br/>                     If this bit is set to 0, NDFC output the data in internal RAM or do nothing after fetching data from Flash.</p> |
| 25    | R/W | 0x0 | <p><b>NDFC_SEQ</b><br/>                     User data &amp; BCH check word position. It only is active for Page Command, donot care about this bit for other two commands.<br/>                     0: Interleave Method (on page spare area)<br/>                     1: Sequence Method (following data block)</p>                                                                                                                                                                                                                                                                                                                                                                                       |
| 24    | R/W | 0x0 | <p><b>NDFC_SEND_SECOND_CMD</b><br/>                     0: Donot send second set command<br/>                     1: Send it on the external memory's bus</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23    | R/W | 0x0 | <p><b>NDFC_WAIT_FLAG</b><br/>                     0: NDFC can transfer data regardless of the internal NDFC_RB wire<br/>                     1: NDFC can transfer data when the internal NDFC_RB wire is READY; otherwise it cannot when the internal NDFC_RB wire is BUSY</p>                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22    | R/W | 0x0 | <p><b>NDFC_SEND_FIRST_CMD</b><br/>                     0: Donot send first set command<br/>                     1: Send it on the external memory's bus</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 21    | R/W | 0x0 | <p><b>NDFC_DATA_TRANS</b><br/>                     0: No data transfer on external memory bus<br/>                     1: Data transfer and direction is decided by the field NDFC_ACCESS_DIR</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 20    | R/W | 0x0 | <p><b>NDFC_ACCESS_DIR</b><br/>                     0: Read NAND Flash<br/>                     1: Write NAND Flash</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19    | R/W | 0x0 | <p><b>NDFC_SEND_ADR</b><br/>                     0: Donot send ADDRESS<br/>                     1: Send N cycles ADDRESS, the number N is specified by NDFC_ADR_NUM field</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18:16 | R/W | 0x0 | <p><b>NDFC_ADR_NUM</b><br/>                     Address Cycles' Number<br/>                     000: 1 cycle address field<br/>                     001: 2 cycles address field<br/>                     010: 3 cycles address field<br/>                     011: 4 cycles address field<br/>                     100: 5 cycles address field<br/>                     101: 6 cycles address field<br/>                     110: 7 cycles address field</p>                                                                                                                                                                                                                                               |

|       |     |     |                                                                                                                                                                 |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 111: 8 cycles address field                                                                                                                                     |
| 15:10 | /   | /   | /                                                                                                                                                               |
| 9:8   | R/W | 0x0 | <p>NDFC_ADR_NUM_IN_PAGE_CMD<br/>The number of address cycles during page command.</p> <p>00: 2 address cycles<br/>11: 5 address cycles<br/>Others: reserved</p> |
| 7:0   | R/W | 0x0 | <p>NDFC_CMD_LOW_BYTE<br/>NDFC command low byte data</p> <p>This command will be sent to external Flash by NDFC.</p>                                             |

#### 5.2.6.11. 0x0028 NDFC Command Set Register 0(Default Value: 0x00E0\_0530)

| Offset: 0x0028 |            |             | Register Name: NDFC_CMD_SET0                                   |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:24          | R/W        | 0x00        | <p>NDFC_RANDOM_CMD2<br/>Used for Batch Operation</p>           |
| 23:16          | R/W        | 0xE0        | <p>NDFC_RANDOM_READ_CMD1<br/>Used for Batch Read Operation</p> |
| 15:8           | R/W        | 0x05        | <p>NDFC_RANDOM_READ_CMD0<br/>Used for Batch Read Operation</p> |
| 7:0            | R/W        | 0x30        | <p>NDFC_READ_CMD<br/>Used for Batch Read Operation</p>         |

#### 5.2.6.12. 0x002C NDFC Command Set Register 1(Default Value: 0x7000\_8510)

| Offset: 0x002C |            |             | Register Name: NDFC_CMD_SET1                                    |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:24          | R/W        | 0x70        | <p>NDFC_READ_CMD0<br/>Used for EF-NAND Page Read Operation</p>  |
| 23:16          | R/W        | 0x00        | <p>NDFC_READ_CMD1<br/>Used for EF-NAND Page Read Operation</p>  |
| 15:8           | R/W        | 0x85        | <p>NDFC_RANDOM_WRITE_CMD<br/>Used for Batch Write Operation</p> |
| 7:0            | R/W        | 0x10        | <p>NDFC_PROGRAM_CMD<br/>Used for Batch Write Operation</p>      |

#### 5.2.6.13. 0x0034 NDFC ECC Control Register(Default Value: 0x4A80\_0008)

| Offset: 0x0034 |            |             | Register Name: NDFC_ECC_CTL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |

|       |     |        |                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | /   | /      | /                                                                                                                                                                                                                                                                                                                                                     |
| 30:16 | R/W | 0x4a80 | <b>NDFC_RANDOM_SEED</b><br>The seed value for randomize engine. It is only active when NDFC_RANDOM_EN is set to '1'.                                                                                                                                                                                                                                  |
| 15:8  | R/W | 0x0    | <b>NDFC_ECC_MODE</b><br>00000000: BCH-16<br>00000001: BCH-24<br>00000010: BCH-28<br>00000011: BCH-32<br>00000100: BCH-40<br>00000101: BCH-44<br>00000110: BCH-48<br>00000111: BCH-52<br>00001000: BCH-56<br>00001001: BCH-60<br>00001010: BCH-64<br>00001011: BCH-68<br>00001100: BCH-72<br>00001101: BCH-76<br>00001110: BCH-80<br>Others : Reserved |
| 7     | R/W | 0x0    | <b>NDFC_RANDOM_SIZE</b><br>0: ECC block size<br>1: Page size                                                                                                                                                                                                                                                                                          |
| 6     | R/W | 0x0    | <b>NDFC_RANDOM_DIRECTION</b><br>0: LSB first<br>1: MSB first                                                                                                                                                                                                                                                                                          |
| 5     | R/W | 0x0    | <b>NDFC_RANDOM_EN</b><br>0: Disable Data Randomize<br>1: Enable Data Randomize                                                                                                                                                                                                                                                                        |
| 4     | R/W | 0x0    | <b>NDFC_ECC_EXCEPTION</b><br>0: Normal ECC<br>1: For ECC, there is an exception. If all data is 0xff or 0x00 for the block. When reading this page, ECC assumes that it is right. For this case, no error information is reported.<br><b>Note: It is only active when ECC is ON</b>                                                                   |
| 3     | R/W | 0x1    | <b>NDFC_ECC_PIPELINE</b><br>Pipeline function enable or disable for batch command<br>0: Error Correction function no pipeline with next block operation<br>1: Error Correction pipeline                                                                                                                                                               |
| 2:1   | /   | /      | /                                                                                                                                                                                                                                                                                                                                                     |
| 0     | R/W | 0x0    | <b>NDFC_ECC_EN</b><br>0: ECC is OFF<br>1: ECC is ON                                                                                                                                                                                                                                                                                                   |

## 5.2.6.14. 0x0038 NDFC ECC Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: NDFC_ECC_ST                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                |
| 31             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 31</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[31] of this register is corresponding the 31th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 30             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 30</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[30] of this register is corresponding the 30th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 29             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 29</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[29] of this register is corresponding the 29th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 28             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 28</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[28] of this register is corresponding the 28th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 27             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 27</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[27] of this register is corresponding the 27th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 26             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 26</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[26] of this register is corresponding the 26th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 25             | R          | 0x0         | <p>NDFC_ECC_ERR</p> <p>Error information bit of Data Block 25</p> <p>0: ECC can correct these error bits or there is no error bit</p> <p>1: Error bits number beyond of ECC correction capability and cannot correct them</p> <p>The bit[25] of this register is corresponding the 25th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |

|    |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |   |     | Block = 1024 bytes.                                                                                                                                                                                                                                                                                                                                                                                                |
| 24 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 24<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[24] of this register is corresponding the 24th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 23 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 23<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[23] of this register is corresponding the 23th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 22 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 22<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[22] of this register is corresponding the 22th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 21 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 21<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[21] of this register is corresponding the 21th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 20 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 20<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[20] of this register is corresponding the 20th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 19 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 19<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[19] of this register is corresponding the 19th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 18 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 18<br/>                     0: ECC can correct these error bits or there is no error bit<br/>                     1: Error bits number beyond of ECC correction capability and cannot correct them<br/>                     The bit[18] of this register is corresponding the 18th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 17 | R | 0x0 | <p>NDFC_ECC_ERR<br/>                     Error information bit of Data Block 17</p>                                                                                                                                                                                                                                                                                                                                |

|    |   |     |                                                                                                                                                                                                                                                                                                                     |
|----|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |   |     | 0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[17] of this register is corresponding the 17th ECC data block. 1 ECC Data Block = 1024 bytes.                                                           |
| 16 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 16<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[16] of this register is corresponding the 16th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 15 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 15<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[15] of this register is corresponding the 15th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 14 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 14<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[14] of this register is corresponding the 14th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 13 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 13<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[13] of this register is corresponding the 13th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 12 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 12<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[12] of this register is corresponding the 12th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 11 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 11<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[11] of this register is corresponding the 11th ECC data block. 1 ECC Data Block = 1024 bytes. |
| 10 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 10<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[10] of this register is corresponding the 10th ECC data block. 1 ECC Data Block = 1024 bytes. |

|   |   |     |                                                                                                                                                                                                                                                                                                                             |
|---|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | Block = 1024 bytes.                                                                                                                                                                                                                                                                                                         |
| 9 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 9<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[9] of this register is corresponding the 9th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 8 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 8<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[8] of this register is corresponding the 8th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 7 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 7<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[7] of this register is corresponding the 7th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 6 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 6<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[6] of this register is corresponding the 6th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 5 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 5<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[5] of this register is corresponding the 5th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 4 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 4<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[4] of this register is corresponding the 4th ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 3 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 3<br/>0: ECC can correct these error bits or there is no error bit<br/>1: Error bits number beyond of ECC correction capability and cannot correct them<br/>The bit[3] of this register is corresponding the 3rd ECC data block. 1 ECC Data Block = 1024 bytes.</p> |
| 2 | R | 0x0 | <p>NDFC_ECC_ERR<br/>Error information bit of Data Block 2</p>                                                                                                                                                                                                                                                               |

|   |   |     |                                                                                                                                                                                                                                                                                                                  |
|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | 0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[2] of this register is corresponding the 2nd ECC data block. 1 ECC Data Block = 1024 bytes.                                                          |
| 1 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 1<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[1] of this register is corresponding the 1st ECC data block. 1 ECC Data Block = 1024 bytes. |
| 0 | R | 0x0 | NDFC_ECC_ERR<br>Error information bit of Data Block 0<br>0: ECC can correct these error bits or there is no error bit<br>1: Error bits number beyond of ECC correction capability and cannot correct them<br>The bit[0] of this register is corresponding the 0 ECC data block. 1 ECC Data Block = 1024 bytes.   |

#### 5.2.6.15. 0x003C NDFC Data Pattern Status Register(Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: NDFC_DATA_PAT_STA                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                         |
| 31             | R          | 0x0         | Special pattern (all 0x00 or all 0xff) found flag for Data Block 31 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 30             | R          | 0x0         | Special pattern (all 0x00 or all 0xff) found flag for Data Block 30 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 29             | R          | 0x0         | Special pattern (all 0x00 or all 0xff) found flag for Data Block 29 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 28             | R          | 0x0         | Special pattern (all 0x00 or all 0xff) found flag for Data Block 28 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 27             | R          | 0x0         | Special pattern (all 0x00 or all 0xff) found flag for Data Block 27 when read from external NAND flash.<br>0: No found                                                                                                              |

|    |   |     |                                                                                                                                                                                                                                     |
|----|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |   |     | 1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found.                                                                                                                           |
| 26 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 26 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 25 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 25 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 24 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 24 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 23 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 23 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 22 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 22 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 21 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 21 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 20 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 20 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 19 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found Flag for Data Block 19 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 18 | R | 0x0 | Special pattern (all 0x00 or all 0xff) Found flag for Data Block 18 when read from external NAND flash.<br>0: No found                                                                                                              |

|    |   |     |                                                                                                                                                                                                                                     |
|----|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |   |     | 1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found.                                                                                                                           |
| 17 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 17 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 16 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 16 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 15 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 15 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 14 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 14 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 13 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 13 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 12 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 12 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 11 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 11 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 10 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 10 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 9  | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 9 when read from external NAND flash.<br>0: No found                                                                                                               |

|   |   |     |                                                                                                                                                                                                                                    |
|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | 1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found.                                                                                                                          |
| 8 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 8 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 7 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 7 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 6 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 6 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 5 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 5 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 4 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 4 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 3 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 3 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 2 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 2 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 1 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 1 when read from external NAND flash.<br>0: No found<br>1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
| 0 | R | 0x0 | Special pattern (all 0x00 or all 0xff) found flag for Data Block 0 when read from external NAND flash.<br>0: No found                                                                                                              |

|  |  |  |                                                                                                           |
|--|--|--|-----------------------------------------------------------------------------------------------------------|
|  |  |  | 1: Special pattern is found<br>The register of NDFC_PAT_ID would indicate which kind of pattern is found. |
|--|--|--|-----------------------------------------------------------------------------------------------------------|

#### 5.2.6.16. 0x0040 NDFC Enhanced Feature Register(Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: NDFC_EFR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 24             | R/W        | 0x0         | DB_CNT_EN<br>Dummy_Byte_Count_EN<br>0:Disable fill Dummy Byte<br>1:Enable fill Dummy Byte                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23:16          | R/W        | 0x0         | DB_CNT<br>Dummy_Byte_Count<br>After PAGE CMD operation finishing sending out the main data , user data and ECC code, controller would send dummy byte to fill the unused space in one page.<br><b>Note: It is only valid in PAGE CMD operation(NDFC_CMD_TYPE=0x3), and this function is disabled when Dummy_Byte_Count_EN is 0.</b><br><b>If the NDFC_RANDOM_EN = 0x0, the value of the dummy byte is 0, so in order to improve the stability, when using this function , it is better to set the NDFC_RANDOM_EN to 0x1.</b> |
| 15:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8              | R/W        | 0x0         | NDFC_WP_CTRL<br>NAND Flash Write Protect Control Bit<br>0: Write Protect is active<br>1: Write Protect is not active<br>When this bit is '0', WP signal line is low level and external NAND flash is on protected state.                                                                                                                                                                                                                                                                                                     |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6:0            | R/W        | 0x0         | NDFC_ECC_DEBUG<br>For the purpose of debugging ECC engine, special error bits are inserted before writing external Flash Memory.<br>0: No error is inserted (ECC Normal Operation)<br>n: N bits error are inserted                                                                                                                                                                                                                                                                                                           |

#### 5.2.6.17. 0x0044 NDFC Read Data Status Control Register(Default Value: 0x0100\_0000)

| Offset: 0x0044 |            |             | Register Name: NDFC_RDATA_STA_CTL |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:25          | /          | /           | /                                 |
| 24             | R/W        | 0x1         | NDFC_RDATA_STA_EN                 |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: Disable to count the number of bit 1 and bit 0 during current read operation<br>1: Enable to count the number of bit 1 and bit 0 during current read operation<br>The number of bit 1 and bit 0 during current read operation can be used to check whether a page is blank or bad.                                                                                    |
| 23:19 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                        |
| 18:0  | R/W | 0x0 | NDFC_RDATA_STA_TH<br><br>The threshold value to generate data status<br><br>If the number of bit 1 during current read operation is less than or equal to threshold value, the bit 13 of NDFC_ST register will be set.<br><br>If the number of bit 0 during current read operation is less than or equal to threshold value, the bit 12 of NDFC_ST register will be set. |

#### 5.2.6.18. 0x0048 NDFC Read Data Status Register 0(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: NDFC_RDATA_STA_0                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:0           | R          | 0x0         | BIT_CNT_1<br><br>The number of input bit 1 during current command. It will be cleared automatically when next command is executed. |

#### 5.2.6.19. 0x004C NDFC Read Data Status Register 1(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: NDFC_RDATA_STA_1                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:0           | R          | 0x0         | BIT_CNT_0<br><br>The number of input bit 0 during current command. It will be cleared automatically when next command is executed. |

#### 5.2.6.20. 0x0050+N\*0x04 NDFC Error Counter Register N(Default Value: 0x0000\_0000)

| Offset: 0x0050+N*0x04(N=0~7) |            |             | Register Name: NDFC_ERR_CNT_N                                                                                                                                                                                                                                                 |
|------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| [8M+7:<br>8M]<br>(M=0~3)     | R          | 0x0         | ECC_COR_NUM<br><br>ECC Corrected Bits Number for ECC Data Block[N*0x04+M]<br>00000000: No corrected bits<br>00000001: 1 corrected bit<br>00000010: 2 corrected bits<br>.....<br>01010000 : 80 corrected bits<br>Others: Reserved<br><b>Note: 1 ECC Data Block =1024 bytes</b> |

**5.2.6.21. 0x0070+N\*0x04 NDFC User Data Length Register N(Default Value: 0x0000\_0000)**

| Offset: 0x0070+N*0x04(N=0~3) |            | Register Name: NDFC_USER_DATA_LEN_N |                                                                                                                                                                                                                                                                                                                                                                            |
|------------------------------|------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex                         | Description                                                                                                                                                                                                                                                                                                                                                                |
| [4M+3 : 4M]<br>(M=0~7)       | R/W        | 0x0                                 | <p>It's used to indicate user data's length of ECC DATA BLOCK[0x08*N+M].</p> <p>0000 : no user data<br/>0001 : 4 bytes user data<br/>0010 : 8 bytes user data<br/>0011 : 12 bytes user data<br/>0100 : 16 bytes user data<br/>0101 : 20 bytes user data<br/>0110 : 24 bytes user data<br/>0111 : 28 bytes user data<br/>1000 : 32 bytes user data<br/>Other : reserved</p> |

**5.2.6.22. 0x0080 + N\*0x04 NDFC User Data Register N(Default Value: 0xFFFF\_FFFF)**

| Offset: 0x0080 + N*0x04(N=0~31) |            |             | Register Name: NDFC_USER_DATA_N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:0                            | R/W        | 0xffffffff  | <p>USER_DATA</p> <p>All of the user data in one page is stored in NDFC_USER_DATA_N.</p> <p>The start register address of each ECC DATA BLOCK's user data is determined by its length configured in NDFC_USER_DATA_LEN_N.</p> <p>For example:</p> <p>ECC DATA BLOCK[0] user data len = 8 Bytes, address = 0x80</p> <p>ECC DATA BLOCK[1] user data len = 0 Bytes,</p> <p>ECC DATA BLOCK[2] user data len = 4 Bytes, address = 0x80+8</p> <p>ECC DATA BLOCK[3] user data len = 4 Bytes, address = 0x80+8+4</p> <p>ECC DATA BLOCK[4] user data len = 0 Bytes</p> <p>ECC DATA BLOCK[5] user data len = 16 Bytes, address = 0x80+8+4+4</p> <p>ECC DATA BLOCK[6] user data len = 0 Bytes</p> <p>ECC DATA BLOCK[7] user data len = 0 Bytes</p> |

**5.2.6.23. 0x110 NDFC EFNAND Status Register(Default Value: 0x0000\_0000)**

| Offset: 0x0110 |            |             | Register Name: NDFC_EFNAND_STATUS                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:8           | /          | /           | /                                                                             |
| 7:0            | R          | 0x0         | <p>EF_NAND_STATUS</p> <p>The status value for EF-NAND page read operation</p> |

**5.2.6.24. 0x0114 NDFC Spare Area Register(Default Value: 0x0000\_0400)**

| Offset: 0x0114 |            |             | Register Name: NDFC_SPARE_AREA                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
| 31:16          | /          | /           | /                                                                                                            |
| 15:0           | R/W        | 0x400       | NDFC_SPARE_ADR<br>This value indicates the spare area first byte address for NDFC interleave page operation. |

**5.2.6.25. 0x0118 NDFC Pattern ID Register(Default Value: 0x0000\_0000)**

| Offset: 0x0118 |            |             | Register Name: NDFC_PAT_ID                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| n<br>(n=0~31)  | R          | 0x0         | PAT_ID<br>Special Pattern ID for ECC data block[n]<br>0: All 0x00 is found<br>1: All 0xFF is found |

**5.2.6.26. 0x011C NDFC DDR2 Specific Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x011C |            |             | Register Name: NDFC_DDR2_SPEC_CTL                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                      |
| 15:12          | R/W        | 0x0         | DLEN_WR<br>The number of latency DQS cycle for write<br>0000: No latency<br>0001: One latency DQS cycle<br>0010: Two latency DQS cycle<br>0011: Four latency DQS cycle |
| 11:8           | R/W        | 0x0         | DLEN_RD<br>The number of latency DQS cycle for read<br>0000: No latency<br>0001: One latency DQS cycle<br>0010: Two latency DQS cycle<br>0011: Four latency DQS cycle  |
| 7:3            | /          | /           | /                                                                                                                                                                      |
| 2              | R/W        | 0x0         | EN_RE_C<br>Enable the complementary RE# signal<br>0: Disable<br>1: Enable                                                                                              |
| 1              | R/W        | 0x0         | EN_DQS_C<br>Enable the complementary DQS signal                                                                                                                        |

|   |   |   |                         |
|---|---|---|-------------------------|
|   |   |   | 0: Disable<br>1: Enable |
| 0 | / | / | /                       |

#### 5.2.6.27. 0x0120 NDFC Normal DMA Mode Control Register(Default Value: 0x0000\_00E5)

| Offset: 0x0120 |            |             | Register Name: NDFC_NDMA_MODE_CTL                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31:8           | /          | /           | /                                                                                                                                                            |
| 7:6            | R/W        | 0x11        | DMA_ACT_STA<br>00:dma_active is low<br>01:dma_active is high<br>10:dma_active is controlled by dma_request(DRQ)<br>11:dma_active is controlled by controller |
| 5              | R/W        | 0x1         | DMA_ACK_EN<br>0: active fall do not care ack<br>1: active fall must after detect ack is high                                                                 |
| 4:0            | R/W        | 0x05        | DELAY_CYCLE<br>The counts of hold cycles from DMA last signal high to dma_active high                                                                        |

#### 5.2.6.28. 0x0200 NDFC MBUS DMA Descriptor List Base Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: NDFC_MDMA_DLBA_REG                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:0           | R/W        | 0x0         | NFC_MDMA_DESC_BASE_ADDR<br>Start Address of Descriptor List<br>Contains the base address of the First Descriptor. The LSB bits [1:0] are ignored and taken as all-zero by the DMA internally. Hence these LSB bits are read-only. |

#### 5.2.6.29. 0x0204 NDFC MBUS DMA Interrupt Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0204 |            |             | Register Name: NDFC_MDMA_STA                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                 |
| 31:0           | R/W        | 0x0         | NFC_MDMA_TRANS_FINISH_INT<br>Transfer Finish Interrupt<br>Indicates that data transmission is finished for a descriptor. Writing a '1' clears this bit.<br>Bit 0: Corresponding DMA descriptor 0<br>Bit 1: Corresponding DMA descriptor 1<br>...<br>Bit 31: Corresponding DMA descriptor 31 |

#### 5.2.6.30. 0x0208 NDFC MBUS DMA Interrupt Enable Register(Default Value: 0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: NDFC_DMA_INT_MASK                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
| 31:0           | R/W        | 0x0         | <p>NFC MDMA_TRANS_INT_ENB<br/>Transfer Interrupt Enable<br/>When set, Transmit Interrupt is enabled. When reset, Transmit Interrupt is disabled.</p> <p>Bit 0: Corresponding DMA descriptor 0<br/>Bit 1: Corresponding DMA descriptor 1<br/>...<br/>Bit 31: Corresponding DMA descriptor 31</p> |

#### 5.2.6.31. 0x020C NDFC MBUS DMA Current Descriptor Address Register(Default Value: 0x0000\_0000)

| Offset: 0x020C |            |             | Register Name: NDFC_MDMA_CUR_DESC_ADDR                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:0           | R          | 0x0         | <p>CUR_DESC_ADDR<br/>Current Descriptor Address Pointer<br/>Cleared on reset. Pointer updated by DMA during operation. This register points to the start address of the current descriptor read by the DMA.</p> |

#### 5.2.6.32. 0x0210 NDFC MBUS DMA Current Buffer Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0210 |            |             | Register Name: NDFC_MDMA_CUR_BUF_ADDR                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | R          | 0x0         | <p>CUR_BUFF_ADDR<br/>Current Buffer Address Pointer<br/>Cleared on Reset. Pointer updated by DMA during operation. This register points to the current Data Buffer Address being accessed by the DMA.</p> |

#### 5.2.6.33. 0x0214 NDFC DMA Byte Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: NDFC_DMA_CNT                                    |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:16          | /          | /           | /                                                              |
| 15:0           | R/W        | 0x0         | DMA_CNT<br>DMA data counter, including MBUS DMA and Normal DMA |

#### 5.2.6.34. 0x0300 NDFC IO Data Register(Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: NDFC_IO_DATA                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:0           | R/W        | 0x0         | NDFC_IO_DATA<br>Read/Write data into internal RAM<br>Access unit is 32-bit. |

## 5.3. SD/MMC Host Controller (SMHC)

### 5.3.1. Overview

The SD-MMC Host Controller(SMHC) controls the read/write operations on the secure digital(SD) card and multimedia card(MMC), and supports various extended devices based on the secure digital input/output(SDIO) protocol. The A133 provides three SMHC interfaces for controlling the SD card, MMC and SDIO device.

The SMHC has the following features:

- Supports eMMC boot operation
- Supports command completion signal and interrupt to host processor and command completion signal disable feature
- SMHC0 supports SD (Version1.0 to 3.0), 4-bit bus width
  - SDR mode 150 MHz@1.8V IO pad
  - DDR mode 100 MHz@1.8V IO pad
  - DDR mode 50 MHz@3.3V IO pad
- SMHC1 supports SDIO (Version1.1 to 3.0), 4-bit bus width
  - SDR mode 150 MHz@1.8V IO pad
  - DDR mode 100 MHz@1.8V IO pad
  - DDR mode 50 MHz@3.3V IO pad
- SMHC2 supports MMC (Version3.3 to 5.1), 8-bit bus width
  - SDR mode 50 MHz@3.3V IO pad
  - DDR mode 50 MHz@3.3V IO pad
  - SDR mode 150 MHz@1.8V IO pad
  - DDR mode 100 MHz@1.8V IO pad
- Hardware CRC generation and error detection
- Programmable baud rate
- Host pull-up control
- Supports SDIO interrupt in 1-bit and 4-bit modes
- Block size of 1 to 65535 bytes
- Descriptor-based internal DMA controller
- Internal 1 KB FIFO for data transfer

### 5.3.2. Block Diagram

Figure 5-17 shows a block diagram of the SMHC.



Figure 5- 17. SMHC Block Diagram

### 5.3.3. Operations and Functional Descriptions

#### 5.3.3.1. External Signals

Table 5-3 describes the external signals of SMHC.

Table 5- 3. SMHC External Signals

| Port Name         | Width | Type   | Description                 |
|-------------------|-------|--------|-----------------------------|
| SDC0_CLK          | 1     | O      | Clock output for SD/TF card |
| SDC0_CMD          | 1     | I/O,OD | CMD line for SD/TF card     |
| SDC0_D[i] (i=0~3) | 4     | I/O    | Data line for SD/TF card    |
| SDC1_CLK          | 1     | O      | Clock output for SDIO Wi-Fi |
| SDC1_CMD          | 1     | I/O,OD | CMD line for SDIO Wi-Fi     |
| SDC1_D[i] (i=0~3) | 4     | I/O    | Data line for SDIO Wi-Fi    |
| SDC2_CLK          | 1     | O      | Clock output for MMC        |
| SDC2_CMD          | 1     | I/O,OD | CMD line for MMC            |
| SDC2_D[i] (i=0~7) | 8     | I/O    | Data line for MMC           |
| SDC2_RST          | 1     | O      | Reset signal for MMC        |
| SDC2_DS           | 1     | I      | Data strobe for MMC         |

#### 5.3.3.2. Clock Sources

Each SMHC gets three different clocks. User can select one of them to make SMHC clock source. Table 5-4 describes the clock sources of SMHC. Users can see CCU in chapter 3.3 for clock setting, configuration and gating information.

## **Table 5- 4. SMHC Clock Sources**

| Clock Sources | Description                                    |
|---------------|------------------------------------------------|
| OSC24M        | 24 MHz Crystal                                 |
| PLL_PERI0(2X) | Peripheral Clock, the default value is 1.2 GHz |
| PLL_PERI1(2X) | Peripheral Clock, the default value is 1.2 GHz |

### 5.3.3.3. Timing Diagram

Please refer to 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)

#### **5.3.3.4. Internal DMA Controller Description**

SMHC has an internal DMA controller (IDMAC) to transfer data between host memory and SMHC port. With a descriptor, IDMAC can efficiently move data from source to destination by automatically loading next DMA transfer arguments, which need less CPU intervention. Before transfer data in IDMAC, host driver should construct a descriptor list, configure arguments of every DMA transfer, then launch the descriptor and start the DMA. IDMAC has an interrupt controller, when enabled, it can interrupt the HOST CPU in situations such as data transmission completed or some errors happened.

#### **5.3.3.4.1. IDMAC Descriptor Structure**

The IDMAC uses a descriptor with a chain structure, and each descriptor points to a unique buffer and the next descriptor.



**Figure 5- 18. 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 is a notation used to denote the [31:0] bits, DES1 to denote [63:32] bits, DES2 to denote [95:64] bits, and DES3 to denote [127:96] bits in a descriptor.

#### 5.3.3.4.2. DES0 Definition

| Bits | Name                            | Descriptor                                                                                                                                                                                                           |
|------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | HOLD                            | DES_OWN_FLAG<br>When set, this bit indicates that the descriptor is owned by the IDMAC.<br>When this bit is reset, it indicates that the descriptor is owned by the host. This bit is cleared when transfer is over. |
| 30   | ERROR                           | ERR_FLAG<br>When some error happened in transfer, this bit will be set.                                                                                                                                              |
| 29:5 | /                               | /                                                                                                                                                                                                                    |
| 4    | Chain Flag                      | CHAIM_MOD<br>When set, this bit indicates that the second address in descriptor is the next descriptor address. Must be set to 1.                                                                                    |
| 3    | First DES Flag                  | FIRST_FLAG<br>When set, this bit indicates that this descriptor contains the first buffer of data. Must be set to 1 in first DES.                                                                                    |
| 2    | Last DES Flag                   | LAST_FLAG<br>When set, this bit indicates that the buffers pointed to by this descriptor are the last data buffer.                                                                                                   |
| 1    | Disable Interrupt on completion | CUR_TXRX_OVER_INT_DIS<br>When set, this bit will prevent the setting of the TX/RX interrupt bit of the IDMAC status register for data that ends in the buffer pointed to by this descriptor.                         |
| 0    | /                               | /                                                                                                                                                                                                                    |

#### 5.3.3.4.3. DES1 Definition

| Bits  | Name        | Descriptor                                                                                                                                                                            |
|-------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | /           | /                                                                                                                                                                                     |
| 12:0  | Buffer size | BUFF_SIZE<br>These 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. |

#### 5.3.3.4.4. DES2 Definition

| Bits | Name | Descriptor |
|------|------|------------|
|      |      |            |

|      |                        |                                                                                                       |
|------|------------------------|-------------------------------------------------------------------------------------------------------|
| 31:0 | Buffer address pointer | <b>BUFF_ADDR</b><br>These bits indicate the physical address of data buffer.<br>It is a word address. |
|------|------------------------|-------------------------------------------------------------------------------------------------------|

#### 5.3.3.4.5. DES3 Definition

| Bits | Name                    | Descriptor                                                                                                                                     |
|------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Next descriptor address | <b>NEXT_DESP_ADDR</b><br>These bits indicate the pointer to the physical memory where the next descriptor is present.<br>It is a word address. |

#### 5.3.3.5. Calibrate Delay Chain

There are two delay chains in SMHC v5.30. One is Data Strobe delay chain, used to generate delay to make proper timing between Data Strobe and data signals. Another is sample delay chain, used to generate delay to make proper timing between 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.

The steps to calibrate delay chain are as follows:

**Step1:** Enable SMHC. In order to calibrate delay chain by operation registers in SMHC, SMHC must be enabled through **SMHC Bus Gating Reset Register** and **SMHC0/1/2 Clock Register**.

**Step2:** Configure a proper clock for SMHC. Calibration delay chain is based on the clock for SMHC from Clock Control Unit(CCU). Calibration delay chain is an internal function in SMHC and does not need device. So, it is unnecessary to open clock signal for device. The recommended clock frequency is 200 MHz.

**Step3:** 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.

**Step4:** Write 0x8000 to **delay control register** to start calibrate delay chain.

**Step5:** 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 SMHC clock nearly. This value is the result of calibration.

**Step6:** Calculate the delay time of one delay cell according to the cycle of SMHC clock and the result of calibration.

### 5.3.4. Programming Guidelines

#### 5.3.4.1. Initialization

Before data and command are exchanged between a card and the SMHC, the SMHC need to be initialized. The SMHC is initialized as follows.

- Step1:** Configure GPIO register as SMHC function by Port Controller module; reset clock by writing 1 to [SMHC\\_BGR\\_REG\[SMHCx\\_RST\]](#), open clock gating by writing 1 to [SMHC\\_BGR\\_REG\[SMHCx\\_GATING\]](#); select clock sources and set division factor by configuring the [SMHCx\\_CLK\\_REG\(x=0,1,2\)](#) register.
- Step2:** Configure [SMHC\\_CTRL](#) to reset FIFO and controller, enable total interrupt; configure [SMHC\\_INTMASK](#) to 0xFFCE to enable normal interrupt and error abnormal interrupt, and register interrupt function.
- Step3:** Configure [SMHC\\_CLKDIV](#) to open clock for device; configure [SMHC\\_CMD](#) as change clock command(for example 0x80202000); send update clock command to deliver clock to device.
- Step4:** Configure [SMHC\\_CMD](#) to normal command, configure [SMHC\\_CMDARG](#) to set command parameter, configure [SMHC\\_CMD](#) to set response type, etc, then command can send. According to initial process in the protocol, you can finish SMHC initializing by sending corresponding command one by one.

#### 5.3.4.2. Writing a Single Data Block

To Write a single data block, perform the following steps:

- Step1:** Write 0x1 to [SMHC\\_CTRL\[DMA\\_RST\]](#) to reset internal DMA controller; write 0x82 to [SMHC\\_IDMAC](#) to enable IDMAC interrupt, configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable transfer interrupt, receive interrupt, and abnormal interrupt.
- Step2:** Configure [SMHC\\_FIFOTH](#) to determine burst size, TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of DMA descriptor.
- Step3:** If writing 1 data block to the sector 1, then [SMHC\\_BYCNT\[BYTE\\_CNT\]](#) need be set to 0x200, the descriptor is set based on data size; set the data sector address of CMD24(Single Data Block Write) to 0x1, write 0x80002758 to [SMHC\\_CMD](#), send CMD24 command to write data to device.
- Step4:** Check whether [SMHC\\_RINTSTS\[CC\]](#) is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.
- Step5:** Check whether [SMHC\\_IDST\\_REG\[TX\\_INT\]](#) is 1. If yes, writing DMA data transfer is complete, then write 0x337 to [SMHC\\_IDST\\_REG](#) to clear interrupt flag; if no, continue to wait until timeout, then exit process.
- Step6:** Check whether [SMHC\\_RINTSTS\[DTC\]](#) is 1. If yes, data transfer is complete and CMD24 writing operation is complete. If no, that is, abnormality exists. Read [SMHC\\_RINTSTS](#),[SMHC\\_STATUS](#) to query existing abnormality.
- Step7:** Send CMD13 command to query whether device writing operation is complete and whether return to 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, then check whether the highest bit of [SMHC\\_RESP0](#)(CMD13 response) is 1. If yes, device is in Idle status, then the next command can be sent. If no, device is in busy status, then continue to send CMD13 to wait device in the idle status until timeout exit.

### 5.3.4.3. Reading a Single Data Block

To read a single data block, perform the following steps:

- Step1:** Write 0x1 to [SMHC\\_CTRL\[DMA\\_RST\]](#) to reset internal DMA controller; write [SMHC\\_IDMAC](#) to 0x82 to enable IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable transfer interrupt, receive interrupt, and abnormal interrupt.
- Step2:** Configure [SMHC\\_FIFOTH](#) to determine burst size, TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of DMA descriptor.
- Step3:** If reading 1 data block from the sector 1, then [SMHC\\_BYCNT\[BYTE\\_CNT\]](#) need be set to 0x200, the descriptor is set based on data size; set the data sector address of CMD17 command(Single Data Block Read) to 0x1, write 0x80002351 to [SMHC\\_CMD](#), send CMD17 command to read data from device to DRAM/SRAM.
- Step4:** Check whether [SMHC\\_RINTSTS\[CC\]](#) is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.
- Step5:** Check whether [SMHC\\_IDST\\_REG\[RX\\_INT\]](#) is 1. If yes, writing DMA data transfer is complete, then write 0x337 to [SMHC\\_IDST\\_REG](#) to clear interrupt flag; if no, continue to wait until timeout, then exit process.
- Step6:** Check whether [SMHC\\_RINTSTS\[DTC\]](#) is 1. If yes, data transfer is complete and CMD17 reading operation is complete. If no, that is, abnormality exists. Read [SMHC\\_RINTSTS](#), [SMHC\\_STATUS](#) to query existing abnormality.

### 5.3.4.4. Writing Open-ended Multiple Data Blocks(CMD25+Auto CMD12)

To write open-ended multiple data blocks, perform the following steps:

- Step1:** Write 0x1 to [SMHC\\_CTRL\[DMA\\_RST\]](#) to reset internal DMA controller; write [SMHC\\_IDMAC](#) to 0x82 to enable IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable transfer interrupt, receive interrupt, and abnormal interrupt.
- Step2:** Configure [SMHC\\_FIFOTH](#) to determine burst size, TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of DMA descriptor.
- Step3:** If writing 3 data blocks to the sector 0, then [SMHC\\_BYCNT\[BYTE\\_CNT\]](#) need be set to 0x600, the descriptor is set based on data size; set the data sector address of CMD25 command(Multiple Data Blocks Write) to 0x0, write 0x80003759 to [SMHC\\_CMD](#), send CMD25 command to write data to device, when data transfer is complete, CMD12 will be sent automatically.
- Step4:** Check whether [SMHC\\_RINTSTS\[CC\]](#) is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.
- Step5:** Check whether [SMHC\\_IDST\\_REG\[TX\\_INT\]](#) is 1. If yes, writing DMA data transfer is complete, then write 0x337 to [SMHC\\_IDST\\_REG](#) to clear interrupt flag; if no, continue to wait until timeout, then exit process.
- Step6:** Check whether [SMHC\\_RINTSTS\[ACD\]](#) and [SMHC\\_RINTSTS\[DTC\]](#) are all 1. If yes, data transfer is complete, CMD12 transfer is complete and CMD25 writing operation is complete. If no, that is, abnormality exists. Read [SMHC\\_RINTSTS](#), [SMHC\\_STATUS](#) to query existing abnormality.
- Step7:** Send CMD13 command to query whether device writing operation is complete and whether return to 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, then check whether the highest bit of

**SMHC\_RESP0**(CMD13 response) is 1. If yes, device is in Idle status, then the next command can be sent. If no, device is in busy status, then continue to send CMD13 to wait device in the idle status until timeout exit.

#### 5.3.4.5. Reading Open-ended Multiple Data Blocks(CMD18+Auto CMD12)

To read open-ended multiple data blocks, perform the following steps:

- Step1:** Write 0x1 to **SMHC\_CTRL[DMA\_RST]** to reset internal DMA controller; write **SMHC\_IDMAC** to 0x82 to enable IDMAC interrupt and configure AHB master burst transfers; configure **SMHC\_IDIE** to enable transfer interrupt, receive interrupt, and abnormal interrupt.
- Step2:** Configure **SMHC\_FIFOTH** to determine burst size, TX/RX trigger level. For example, if **SMHC\_FIFOTH** is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure **SMHC\_DLBA** to determine the start address of DMA descriptor.
- Step3:** If reading 3 data blocks from the sector 0, then **SMHC\_BYCNT[BYTE\_CNT]** need be set to 0x600, the descriptor is set based on data size; set the data sector address of CMD18 command(Multiple Data Blocks Read) to 0x0, write 0x800003352 to **SMHC\_CMD**, send CMD18 command to read data to device, when data transfer is complete, CMD12 will be sent automatically.
- Step4:** Check whether **SMHC\_RINTSTS[CC]** is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.
- Step5:** Check whether **SMHC\_IDST\_REG[RX\_INT]** is 1. If yes, writing DMA data transfer is complete, then write 0x337 to **SMHC\_IDST\_REG** to clear interrupt flag; if no, continue to wait until timeout, then exit process.
- Step6:** Check whether **SMHC\_RINTSTS[ACD]** and **SMHC\_RINTSTS[DTC]** are all 1. If yes, data transfer is complete, CMD12 transfer is complete and CMD18 reading operation is complete. If no, that is, abnormality exists. Read **SMHC\_RINTSTS**, **SMHC\_STATUS** to query existing abnormality.

#### 5.3.4.6. Writing Pre-defined Multiple Data Blocks(CMD23+CMD25)

To write pre-defined multiple data blocks, perform the following steps:

- Step1:** Write 0x1 to **SMHC\_CTRL[DMA\_RST]** to reset internal DMA controller; write **SMHC\_IDMAC** to 0x82 to enable IDMAC interrupt and configure AHB master burst transfers; configure **SMHC\_IDIE** to enable transfer interrupt, receive interrupt, and abnormal interrupt.
- Step2:** Configure **SMHC\_FIFOTH** to determine burst size, TX/RX trigger level. For example, if **SMHC\_FIFOTH** is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure **SMHC\_DLBA** to determine the start address of DMA descriptor.
- Step3:** If writing 3 data blocks, setting **SMHC\_CMDARG** to 0x3 to ensure the block number to be operated, writing 0x80000157 to **SMHC\_CMD** to send CMD23 command. Check whether **SMHC\_RINTSTS[CC]** is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.
- Step4:** **SMHC\_BYCNT[BYTE\_CNT]** need be set to 0x600, the descriptor is set based on data size; set the data sector address of CMD25 command(Multiple Data Blocks Write) to 0x0, write 0x80002759 to **SMHC\_CMD**, send CMD25 command to write data to device.
- Step5:** Check whether **SMHC\_RINTSTS[CC]** is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.

**Step6:** Check whether [SMHC\\_IDST\\_REG\[TX\\_INT\]](#) is 1. If yes, writing DMA data transfer is complete, then write 0x337 to [SMHC\\_IDST\\_REG](#) to clear interrupt flag; if no, continue to wait until timeout, then exit process.

**Step7:** Check whether [SMHC\\_RINTSTS\[DTC\]](#) is 1. If yes, data transfer is complete and CMD25 writing operation is complete. If no, that is, abnormality exists. Read [SMHC\\_RINTSTS](#),[SMHC\\_STATUS](#) to query existing abnormality.

**Step8:** Send CMD13 command to query whether device writing operation is complete and whether return to 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, then check whether the highest bit of [SMHC\\_RESPO](#)(CMD13 response) is 1. If yes, device is in Idle status, then the next command can be sent. If no, device is in busy status, then continue to send CMD13 to wait device in the idle status until timeout exit.

#### 5.3.4.7. Reading Pre-defined Multiple Data Blocks(CMD23+CMD18)

To read pre-defined multiple data blocks, perform the following steps:

**Step1:** Write 0x1 to [SMHC\\_CTRL\[DMA\\_RST\]](#) to reset internal DMA controller; write [SMHC\\_IDMAC](#) to 0x82 to enable IDMAC interrupt and configure AHB master burst transfers; configure [SMHC\\_IDIE](#) to enable transfer interrupt, receive interrupt, and abnormal interrupt.

**Step2:** Configure [SMHC\\_FIFOTH](#) to determine burst size, TX/RX trigger level. For example, if [SMHC\\_FIFOTH](#) is configured as 0x300F00F0, which indicates that Burst size is 16, TX\_TL is 15, RX\_TL is 240. Configure [SMHC\\_DLBA](#) to determine the start address of DMA descriptor.

**Step3:** If reading 3 data blocks, setting [SMHC\\_CMDARG](#) to 0x3 to ensure the block number to be operated, writing 0x80000157 to [SMHC\\_CMD](#) to send CMD23 command. Check whether [SMHC\\_RINTSTS\[CC\]](#) is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.

**Step4:** [SMHC\\_BYCNT\[BYTE\\_CNT\]](#) need be set to 0x600, the descriptor is set based on data size; set the data sector address of CMD18(Multiple Data Blocks Read) to 0x0, write 0x80002352 to [SMHC\\_CMD](#), send CMD18 command to read data from device to DRAM/SRAM.

**Step5:** Check whether [SMHC\\_RINTSTS\[CC\]](#) is 1. If yes, command sends successful; if no, continue to wait until timeout, then exit process.

**Step6:** Check whether [SMHC\\_IDST\\_REG\[TX\\_INT\]](#) is 1. If yes, writing DMA data transfer is complete, then write 0x337 to [SMHC\\_IDST\\_REG](#) to clear interrupt flag; if no, continue to wait until timeout, then exit process.

**Step7:** Check whether [SMHC\\_RINTSTS\[DTC\]](#) is 1. If yes, data transfer is complete and CMD18 writing operation is complete. If no, that is, abnormality exists. Read [SMHC\\_RINTSTS](#),[SMHC\\_STATUS](#) to query existing abnormality.

#### 5.3.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| SMHC0       | 0x04020000   |
| SMHC1       | 0x04021000   |
| SMHC2       | 0x04022000   |

| Register Name | Offset | Description      |
|---------------|--------|------------------|
| SMHC_CTRL     | 0x0000 | Control Register |

|                   |        |                                                              |
|-------------------|--------|--------------------------------------------------------------|
| SMHC_CLKDIV       | 0x0004 | Clock Control Register                                       |
| SMHC_TMOOUT       | 0x0008 | Time Out Register                                            |
| SMHC_CTYPE        | 0x000C | Bus Width Register                                           |
| SMHC_BLKSIZ       | 0x0010 | Block Size Register                                          |
| SMHC_BYTCNT       | 0x0014 | Byte Count Register                                          |
| SMHC_CMD          | 0x0018 | Command Register                                             |
| SMHC_CMDARG       | 0x001C | Command Argument Register                                    |
| SMHC_RESP0        | 0x0020 | Response 0 Register                                          |
| SMHC_RESP1        | 0x0024 | Response 1 Register                                          |
| SMHC_RESP2        | 0x0028 | Response 2 Register                                          |
| SMHC_RESP3        | 0x002C | Response 3 Register                                          |
| SMHC_INTMASK      | 0x0030 | Interrupt Mask Register                                      |
| SMHC_MINTSTS      | 0x0034 | Masked Interrupt Status Register                             |
| SMHC_RINTSTS      | 0x0038 | Raw Interrupt Status Register                                |
| SMHC_STATUS       | 0x003C | Status Register                                              |
| SMHC_FIFOTH       | 0x0040 | FIFO Water Level Register                                    |
| SMHC_FUNS         | 0x0044 | FIFO Function Select Register                                |
| SMHC_TCBCNT       | 0x0048 | Transferred Byte Count between Controller and Card           |
| SMHC_TBBCNT       | 0x004C | Transferred Byte Count between Host Memory and Internal FIFO |
| SMHC_DBGC         | 0x0050 | Current Debug Control Register                               |
| SMHC_CSDC         | 0x0054 | CRC Status Detect Control Registers                          |
| SMHC_A12A         | 0x0058 | Auto Command 12 Argument Register                            |
| SMHC_NTSR         | 0x005C | SD New Timing Set Register                                   |
| SMHC_HWRST        | 0x0078 | Hardware Reset Register                                      |
| SMHC_IDMAC        | 0x0080 | IDMAC Control Register                                       |
| SMHC_DLBA         | 0x0084 | Descriptor List Base Address Register                        |
| SMHC_IDST         | 0x0088 | IDMAC Status Register                                        |
| SMHC_IDIE         | 0x008C | IDMAC Interrupt Enable Register                              |
| SMHC_THLD         | 0x0100 | Card Threshold Control Register                              |
| SMHC_SFC          | 0x0104 | Sample FIFO Control Register                                 |
| SMHC_A23A         | 0x0108 | Auto Command 23 Argument Register                            |
| EMMC_DDR_SBIT_DET | 0x010C | eMMC4.5 DDR Start Bit Detection Control Register             |
| SMHC_EXT_CMD      | 0x0138 | Extended Command Register                                    |
| SMHC_EXT RESP     | 0x013C | Extended Response Register                                   |
| SMHC_DRV_DL       | 0x0140 | Drive Delay Control Register                                 |
| SMHC_SMAP_DL      | 0x0144 | Sample Delay Control Register                                |
| SMHC_DS_DL        | 0x0148 | Data Strobe Delay Control Register                           |
| SMHC_HS400_DL     | 0x014C | HS400 Delay Control Register                                 |
| SMHC_FIFO         | 0x0200 | Read/Write FIFO                                              |

### 5.3.6. Register Description

#### 5.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>0: DMA bus<br>1: AHB bus                                                                                                                         |
| 30:13          | /          | /           | /                                                                                                                                                                                   |
| 12             | R/W        | 0x0         | TIME_UNIT_CMD<br>Time unit for command line<br>Time unit is 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 is 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 eMMC's HS400 speed mode is 8-bit DDR, this field should be cleared when 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. |

### 5.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_DATA0<br>0: Do not mask data0 when update clock<br>1: Mask data0 when update clock                                               |
| 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 is 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. |

### 5.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  | DTO_LMT<br>Data Timeout Limit<br>This field can set time of the Host wait for the data from the Device. |

|     |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |      | <p>Ensure to communicate with the Device, this field must be set to maximum that greater than the time <math>N_{AC}</math>.</p> <p>About the <math>N_{AC}</math>, the explanation is as follows:</p> <p>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).</p> <p>When Host read multiple block(CMD18), a 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.</p> <p>When Host writes data, the value is no effect.</p> |
| 7:0 | R/W | 0x40 | <p>RTO_LMT</p> <p>Response Timeout Limit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 5.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         | <p>CARD_WID</p> <p>Card Width</p> <p>00: 1-bit width</p> <p>01: 4-bit width</p> <p>1x: 8-bit width</p> |

#### 5.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       | <p>BLK_SZ</p> <p>Block Size</p> |

#### 5.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       | <p>BYTE_CNT</p> <p>Byte counter</p> <p>Number of bytes to be transferred. It must be integer multiple of Block Size(BLK_SZ) for block transfers.</p> |

**5.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 (CMD_OVER) will be set in interrupt 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, the 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:16          | /          | /           | /                                                                                                                                                                                                                                                                                 |
| 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_ABST_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 | <b>WAIT_PRE_OVER</b><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 | <b>STOP_CMD_FLAG</b><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 <b>SMHC_RESP1</b> will record the response of auto CMD12. |
| 11  | R/W | 0x0 | <b>TRANS_MODE</b><br>Transfer Mode<br>0: Block data transfer command<br>1: Stream data transfer command                                                                                                                                                   |
| 10  | R/W | 0x0 | <b>TRANS_DIR</b><br>Transfer Direction<br>0: Read operation<br>1: Write operation                                                                                                                                                                         |
| 9   | R/W | 0x0 | <b>DATA_TRANS</b><br>Data Transfer<br>0: Without data transfer<br>1: With data transfer                                                                                                                                                                   |
| 8   | R/W | 0x0 | <b>CHK_RESP_CRC</b><br>Check Response CRC<br>0: Do not check response CRC<br>1: Check response CRC                                                                                                                                                        |
| 7   | R/W | 0x0 | <b>LONG_RESP</b><br>Response Type<br>0: Short Response (48 bits)<br>1: Long Response (136 bits)                                                                                                                                                           |
| 6   | R/W | 0x0 | <b>RESP_RCV</b><br>Response Receive<br>0: Command without response<br>1: Command with response                                                                                                                                                            |
| 5:0 | R/W | 0x0 | <b>CMD_IDX</b><br>CMD Index<br>Command index value                                                                                                                                                                                                        |

### 5.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         | <b>CMD_ARG</b><br>Command argument |

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

### 5.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:31] of response |

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

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

### 5.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:17 | /   | /   | /                                                                            |
| 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<br>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     | /   | /   | /                                                                            |

#### 5.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:17 | / | /   | /                                                                                                                                                                                                                                                                                     |
| 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 taken or received CRC status taken is negative. |
| 14    | R | 0x0 | M_ACD_INT<br>Auto Command Done<br>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 taken 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 Index error may occurs. |
| 0 | / | /   | /                                                                                                          |

### 5.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:17          | /          | /           | /                                                                                                                                                                                                                                                                        |
| 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 taken.<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 a error start bit.<br>When set during transmitting data, it means that 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 does not find start bit on data0.<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 taken 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 are enough space in FIFO during transmitting data.<br>This is write-1-to-clear bits.                                                                                             |
| 3  | R/W1C | 0x0 | DTC<br>Data Transfer Complete<br>When set, it means that current command completes even through error occurs.<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 | /     | /   | /                                                                                                                                     |

### 5.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:26          | /          | /           | /                                                                                                                                                                              |
| 25: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<br>1: card present                                                   |
| 7:4            | R          | 0x0         | 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 |

|   |   |     |                                                                                                                                                                                                                                                                                                        |
|---|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | 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 |
| 3 | R | 0x0 | FIFO_FULL<br>FIFO Full<br>1: FIFO full<br>0: FIFO not full                                                                                                                                                                                                                                             |
| 2 | R | 0x1 | FIFO_EMPTY<br>FIFO Empty<br>1: FIFO Empty<br>0: FIFO not Empty                                                                                                                                                                                                                                         |
| 1 | R | 0x1 | FIFO_TX_LEVEL<br>FIFO TX Water Level Flag<br>0: FIFO did not reach transmit trigger level<br>1: FIFO reached transmit trigger level                                                                                                                                                                    |
| 0 | R | 0x0 | FIFO_RX_LEVEL<br>FIFO RX Water Level Flag<br>0: FIFO did not reach receive trigger level<br>1: FIFO reached receive trigger level                                                                                                                                                                      |

### 5.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             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30:28          | R/W        | 0x0         | 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>It should be programmed same as DMA controller multiple transaction size. The units for transfers are the DWORD. A single transfer would be signaled based on this value. Value should be sub-multiple of (RX_TL + 1) and (FIFO_DEPTH - TX_TL)<br>FIFO_DEPTH = 256, FIFO_SIZE = 256 * 32 = 1K |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | Recommended:<br>MSize = 16, TX_TL = 240, RX_TL = 15 (for SMHC2)<br>MSize = 8, TX_TL = 248, RX_TL = 7 (for SMHC0,SMHC1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27:24 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:16 | R/W | 0xF | <p>RX_TL<br/>RX Trigger Level<br/>0x0~0xFE: RX Trigger Level is 0~254<br/>0xFF: Reserved</p> <p>FIFO threshold when FIFO request host to receive data from FIFO. When FIFO data level is greater than this value, DMA is request is raised if DMA enabled, or RX 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:<br/>15 (means greater than 15, for SMHC2)<br/>7 (means greater than 7, for SMHC0,SMHC1)</p>                                         |
| 15:8  | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0   | R/W | 0x0 | <p>TX_TL<br/>TX Trigger Level<br/>0x1~0xFF: TX Trigger Level is 1~255<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:<br/>240(means less than or equal to 240, for SMHC2)<br/>248(means less than or equal to 248, for SMHC0,SMHC1)</p> |

### 5.3.6.18. 0x0044 SMHC 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</p> |

|   |     |     |                                                                                                                                                                                                                                                                                                                                                                      |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | data.<br>Used in SDIO card suspends sequence.<br>This bit is auto-cleared once controller resets to idle state.                                                                                                                                                                                                                                                      |
| 1 | R/W | 0x0 | <b>READ_WAIT</b><br>Read Wait<br>0: Clear SDIO read wait<br>1: Assert SDIO read wait                                                                                                                                                                                                                                                                                 |
| 0 | R/W | 0x0 | <b>HOST_SEND_MMC_IRQRESQ</b><br>Host Send MMC IRQ Response<br>0: Ignored<br>1: Send auto IRQ response<br>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.<br>This bit is auto-cleared after response is sent. |

#### 5.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         | <b>TBC0</b><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. |

#### 5.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         | <b>TBC1</b><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. |

#### 5.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 | CRC_DET_PARA<br>110: HS400 speed mode<br>011: Other speed mode<br>Others: Reserved |

### 5.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:16          | /          | /           | /                                                                                                          |
| 15:0           | R/W        | 0xffff      | SD_A12A<br>Auto CMD12 Argument<br>SD_A12A set the argument of command 12 automatically send by controller. |

### 5.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_SELEC<br>0: Old mode of Sample/Output Timing<br>1: New mode of Sample/Output Timing                                                |
| 30:25          | /          | /           | /                                                                                                                                       |
| 24             | R/W        | 0x1         | CMD_DAT_RX_PHASE_CLR<br>Clear the input phase of command lines and data lines during update clock operation.<br>0: Disable<br>1: Enable |
| 23             | /          | /           | /                                                                                                                                       |
| 22             | R/W        | 0x1         | DAT_CRC_STATUS_RX_PHASE_CLR<br>Clear the input phase of data lines before receive CRC status.<br>0: Disable<br>1: Enable                |
| 21             | R/W        | 0x1         | DAT_TRANS_RX_PHASE_CLR<br>Clear the input phase of data lines before transfer data.<br>0: Disable<br>1: Enable                          |
| 20             | R/W        | 0x1         | DAT_RECV_RX_PHASE_CLR<br>Clear the input phase of data lines before receive data.<br>0: Disable<br>1: Enable                            |

|       |     |     |                                                                                                                                                                                                           |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:17 | /   | /   | /                                                                                                                                                                                                         |
| 16    | R/W | 0x1 | CMD_SEND_RX_PHASE_CLR<br>Clear command rx phase before send command.<br>0: Disable<br>1: Enable                                                                                                           |
| 15:10 | /   | /   | /                                                                                                                                                                                                         |
| 9:8   | R/W | 0x0 | DAT_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) |
| 7:6   | /   | /   | /                                                                                                                                                                                                         |
| 5:4   | R/W | 0x0 | CMD_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                                                 |
| 3:1   | /   | /   | /                                                                                                                                                                                                         |
| 0     | R/W | 0x0 | HS400_NEW_SAMPLE_EN<br>0: Disable hs400 new sample method<br>1: Enable hs400 new sample method                                                                                                            |

#### 5.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           | /          | /           | /                                                                                                                                     |
| 0              | R/W        | 0x1         | HW_RST<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. |

#### 5.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         | 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 refetch descriptor again and do the transfer normally. |
| 30:11          | /          | /           | /                                                                                                                                                                                                                              |

|      |     |     |                                                                                                                                                                                                                                                                                       |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | R   | 0x0 | Reserved                                                                                                                                                                                                                                                                              |
| 7    | R/W | 0x0 | IDMAC_ENB<br>IDMAC Enable<br>When set, the IDMAC is enabled.                                                                                                                                                                                                                          |
| 6:2  | R/W | 0x0 | Reserved                                                                                                                                                                                                                                                                              |
| 1    | R/W | 0x0 | 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. |
| 0    | R/W | 0x0 | 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.                                                                                                                         |

### 5.3.6.26. 0x0084 SMHC Descriptor List Base Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: SMHC_DLBA_REG                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:0           | R/W        | 0x0         | DES_BASE_ADDR<br>Start of Descriptor List<br>Contains the base address of the First Descriptor.<br>It is a word(4 Byte) address. |

### 5.3.6.27. 0x0088 SMHC IDMAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST_REG                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                  |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                            |
| 16:13          | R          | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                     |
| 12:10          | R          | 0x0         | IDMAC_ERR_STA<br>Error Bits<br>Indicates the type of error that caused a Bus Error. Valid only with Fatal Bus Error bit (IDSTS[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>The bit is read-only. |
| 9              | R/W1C      | 0x0         | ABN_INT_SUM(AIS)<br>Abnormal Interrupt Summary<br>Logical OR of the following:                                                                                                                                                                                                                                               |

|     |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       |     | IDSTS[2]: Fatal Bus Interrupt<br>IDSTS[4]: Descriptor Unavailable Bit Interrupt<br>IDSTS[5]: Card Error Summary Interrupt<br>Only unmasked bits affect this bit.<br><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 | NOR_INT_SUM(NIS)<br>Normal Interrupt Summary<br>Logical OR of the following:<br>IDSTS[0]: Transmit Interrupt<br>IDSTS[1]: Receive Interrupt<br>Only unmasked bits affect this bit.<br><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 card; also present in RINTSTS. Indicates the logical OR of the following bits:<br>EBE: End Bit Error<br>RTO: Response Timeout/Boot ACK Timeout<br>RCRC: Response CRC<br>SBE: Start Bit Error<br>DRTO: Data Read Timeout/BDS timeout<br>DCRC: Data CRC for Receive<br>RE: Response Error<br>Writing a 1 clears this bit. |
| 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 (IDSTS[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.

### 5.3.6.28. 0x008C SMHC IDMAC Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: SMHC_IDIE_REG                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:10          | /          | /           | /                                                                                                                                                                                              |
| 9:8            | R/W        | 0x0         | Reserved                                                                                                                                                                                       |
| 7: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<br>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 with 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 with Normal Interrupt Summary Enable, Transmit Interrupt is enabled. When reset, Transmit Interrupt is disabled.                          |

### 5.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:28          | /          | /           | /                                                                                                                             |
| 27:16          | R/W        | 0x0         | CARD_WR_THLD<br>Card Read/Write Threshold Size                                                                                |
| 15:3           | /          | /           | /                                                                                                                             |
| 2              | R/W        | 0x0         | CARD_WR_THLD_ENB<br>Card Write Threshold Enable(HS400)<br>0: Card write threshold disabled<br>1: Card write threshold enabled |

|   |     |     |                                                                                                                                                                                                                                                            |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Host controller initiates write transfer only if card threshold amount of data is available in transmit FIFO                                                                                                                                               |
| 1 | R/W | 0x0 | <p>BCIG (only for SMHC2)</p> <p>Busy Clear Interrupt Generation</p> <p>0: Busy clear interrupt disabled</p> <p>1: Busy clear interrupt enabled</p> <p>The application can disable this feature if it does not want to wait for a Busy Clear Interrupt.</p> |
| 0 | R/W | 0x0 | <p>CARD_RD_THLD_ENB</p> <p>Card Read Threshold Enable</p> <p>0: Card read threshold disabled</p> <p>1: Card read threshold enabled</p> <p>Host controller initiates Read Transfer only if CARD_RD_THLD amount of space is available in receive FIFO.</p>   |

#### 5.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         | <p>STOP_CLK_CTRL</p> <p>Stop Clock Control</p> <p>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.</p> <p>This field is used to control the position of stopping clock.</p> <p>The value can be changed between 0x0 and 0xF, but actually the available value and the position of stopping clock must be decided by the actual situation.</p> <p>The value increases one in this field is linked to one cycle(two cycles in DDR mode) that the position of stopping clock moved up.</p> |
| 0              | R/W        | 0x0         | <p>BYPASS_EN</p> <p>Bypass enable</p> <p>When set, sample FIFO will be bypassed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 5.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         | <p>A23A</p> <p>Auto CMD23 Argument</p> <p>The argument of command 23 is automatically sent by controller with this field.</p> |

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

### 5.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 setting this bit, send CMD23 automatically before send command specified in SMHC_CMD register.<br>When SOFT_RST is set, this field will be cleared. |

### 5.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                                                                             |
| 31:0           | R          | 0x0         | SMHC_EXT_RESP<br>When AUTO_CMD23_EN is set, this register stores the response of CMD23. |

**5.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 90° at SDR mode, 45° at DDR8 mode, 90° at DDR4/HS400 mode<br>1: Data drive phase offset is 180° at SDR mode, 90° at DDR8 mode, 0° at DDR4/HS400 mode            |
| 16             | R/W        | 0x1         | CMD_DRV_PH_SEL<br>Command Drive Phase Select<br>0: Command drive phase offset is 90° at SDR mode, 45° at DDR8 mode, 90° at DDR4/HS400 mode<br>1: Command drive phase offset is 180° at SDR mode, 90° at DDR8 mode, 180° at DDR4/HS400 mode |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                          |

**5.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.<br>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 | <b>SAMP_DL_SW</b><br>Sample Delay Software<br>The relative delay between clock line and command line, data line.<br>It can be determined according to the value of SAMP_DL, the cycle of card clock and the input timing requirement of the device. |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 5.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          | /          | /           | /                                                                                                                                                                                                                                                                       |
| 15             | R/W        | 0x0         | <b>DS_DL_CAL_START</b><br>Data Strobe Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                                                                                                        |
| 14             | R          | 0x0         | <b>DS_DL_CAL_DONE</b><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        | <b>DS_DL</b><br>Data Strobe Delay<br>It indicates the number of delay cells corresponding to current card clock.<br>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         | <b>DS_DL_SW_EN</b><br>Sample Delay Software Enable                                                                                                                                                                                                                      |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                       |
| 5:0            | R/W        | 0x0         | <b>DS_DL_SW</b><br>Data Strobe Delay Software                                                                                                                                                                                                                           |

### 5.3.6.38. 0x014C SMHC HS400 New Timing Delay Control Register(Default Value: 0x0000\_8000)

| Offset: 0x014C |            |             | Register Name: SMHC_HS400_DL                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                              |
| 15             | R/W        | 0x0         | <b>HS400_DL_CAL_START</b><br>HS400 Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                  |
| 14             | R          | 0x0         | <b>HS400_DL_CAL_DONE</b><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 | <p>HS400_DL<br/>HS400 Delay<br/>It indicates the number of delay cells corresponding to current card clock.<br/>The delay time generated by these delay cells is equal to the cycle of SMHC clock nearly.<br/>This bit is valid only when HS400_DL_CAL_DONE is set.</p> |
| 7     | R/W | 0x0 | HS400_DL_SW_EN<br>Sample Delay Software Enable                                                                                                                                                                                                                          |
| 6     | /   | /   | /                                                                                                                                                                                                                                                                       |
| 3:0   | R/W | 0x0 | HS400_DL_SW<br>HS400 Delay Software                                                                                                                                                                                                                                     |

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

## Contents

|                                                     |     |
|-----------------------------------------------------|-----|
| Chapter 6 Video Output Interfaces.....              | 404 |
| 6.1. TCON_LCD .....                                 | 404 |
| 6.1.1. Overview .....                               | 404 |
| 6.1.2. Block Diagram .....                          | 404 |
| 6.1.3. Operations and Functional Descriptions ..... | 405 |
| 6.1.4. Programming Guidelines.....                  | 415 |
| 6.1.5. Register List .....                          | 421 |
| 6.1.6. Register Description .....                   | 422 |
| 6.2. DSI .....                                      | 447 |
| 6.2.1. Overview .....                               | 447 |
| 6.2.2. Block Diagram .....                          | 448 |
| 6.2.3. Operations and Functional Descriptions ..... | 449 |
| 6.2.4. Programming Guidelines.....                  | 456 |
| 6.2.5. Register List .....                          | 457 |
| 6.2.6. Registers Description.....                   | 459 |

## Figures

|                                                                |     |
|----------------------------------------------------------------|-----|
| Figure 6- 1. TCON_LCD Block Diagram.....                       | 404 |
| Figure 6- 2. HV Interface Vertical Timing .....                | 408 |
| Figure 6- 3. HV Interface Horizontal Timing.....               | 409 |
| Figure 6- 4. i8080 Interface Timing .....                      | 411 |
| Figure 6- 5. LVDS Single Link JEDIA Mode Interface Timing..... | 412 |
| Figure 6- 6. LVDS Single Link NS Mode Interface Timing .....   | 412 |
| Figure 6- 7. LVDS Dual Link NS Mode Interface Timing.....      | 413 |
| Figure 6- 8. CMAP Module .....                                 | 415 |
| Figure 6- 9. FRM Module.....                                   | 415 |
| Figure 6- 10. HV Mode Initial Process .....                    | 416 |
| Figure 6- 11. LVDS Mode Configuration Process .....            | 418 |
| Figure 6- 12. i8080 Mode Initial Process.....                  | 420 |
| Figure 6- 13. MIPI DSI Video Mode Data Timing.....             | 421 |
| Figure 6- 14. MIPI DSI System Block Diagram .....              | 448 |
| Figure 6- 15. MIPI DSI Internal Unit .....                     | 448 |
| Figure 6- 16. DPHY Block Diagram .....                         | 449 |
| Figure 6- 17. MIPI DSI Clock System.....                       | 450 |
| Figure 6- 18. DPHY SOT and EOT Timing.....                     | 454 |
| Figure 6- 19. DPHY Escape Mode Timing .....                    | 455 |
| Figure 6- 20. Switching Between HS and LP Timing.....          | 455 |
| Figure 6- 21. Video Mode Initial Sequence .....                | 456 |
| Figure 6- 22. Command Mode Initial Sequence.....               | 457 |

## Tables

|                                                                      |     |
|----------------------------------------------------------------------|-----|
| Table 6- 1. LCD External Signals .....                               | 405 |
| Table 6- 2. HV Panel Signals .....                                   | 407 |
| Table 6- 3. BT656 Panel Signals.....                                 | 409 |
| Table 6- 4. EAV and SAV Sequence .....                               | 410 |
| Table 6- 5. CPU Panel Signals .....                                  | 410 |
| Table 6- 6. LVDS Panel Signals.....                                  | 411 |
| Table 6- 7. TCON_LCD Clock Sources .....                             | 413 |
| Table 6- 8. RGB Gamma Correction .....                               | 414 |
| Table 6- 9. MIPI DSI External Signals.....                           | 449 |
| Table 6- 10. MIPI DSI Controller Clock Sources.....                  | 450 |
| Table 6- 11. MIPI D-PHY Clock Source.....                            | 450 |
| Table 6- 12. Escape Entry Codes .....                                | 451 |
| Table 6- 13. Data Types for Processor-sourced Packets .....          | 451 |
| Table 6- 14. Complete Set of Peripheral-to-Processor Data Types..... | 452 |
| Table 6- 15. Error Report Bit Definitions.....                       | 453 |
| Table 6- 16. D-PHY Lane State.....                                   | 453 |
| Table 6- 17. Entry Command .....                                     | 454 |

# Chapter 6 Video Output Interfaces

## 6.1. TCON\_LCD

### 6.1.1. Overview

The TCON\_LCD (Timing Controller\_LCD) is a module that processes video signals received from system through a complicated arithmetic and then generates control signals and transmits them to the LCD panel driver IC.

The TCON\_LCD includes the following features:

- RGB interface with DE/SYNC mode, up to 1920 x 1200@60fps
- Serial RGB/dummy RGB interface, up to 800 x 480@60fps
- LVDS interface with dual link, up to 1920 x 1200@60fps
- LVDS interface with single link, up to 1366 x 768@60fps
- i8080 interface, up to 800 x 480@60fps
- BT656 interface for NTSC and PAL
- Supports RGB888, RGB666 and RGB565 with dither function
- Supports Gamma correction with R/G/B channel independence

### 6.1.2. Block Diagram



Figure 6- 1. TCON\_LCD Block Diagram

### 6.1.3. Operations and Functional Descriptions

#### 6.1.3.1. External Signals

The LCD external signals are used to connect to panel interface. The panel interface has various types.

**Table 6- 1. LCD External Signals**

| External Signal                         | Description         | Type |
|-----------------------------------------|---------------------|------|
| LCD0_D[7:2],LCD0_D[15:10],LCD0_D[23:18] | LCD data bit        | O    |
| LCD0_CLK                                | LCD clock signal    | O    |
| LCD0_DE                                 | LCD data enable     | O    |
| LCD0_HSYNC                              | LCD horizontal sync | O    |
| LCD0_VSYNC                              | LCD vertical sync   | O    |

#### 6.1.3.1.1. Control Signal and Data Port Mapping

| I/O | SYNC RGB     |                 |                 |        | CPU cmd | CPU 18bit | CPU 16bit       |                 |                 |                 |                 |                 |                 | CPU 8bit |                 |                 |                 | CPU 9bit        |                 |                 |                 |    |    |
|-----|--------------|-----------------|-----------------|--------|---------|-----------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|----|
|     | Parallel RGB | SerialRGB       |                 | CCRG56 |         |           | 256K            |                 |                 |                 |                 |                 |                 | 65K      | 256K            |                 | 65K             |                 | 256K            |                 |                 |    |    |
|     |              | 1 <sup>st</sup> | 2 <sup>nd</sup> |        |         |           | 1 <sup>st</sup> | 2 <sup>nd</sup> | 3 <sup>rd</sup> | 1 <sup>st</sup> | 2 <sup>nd</sup> | 1 <sup>st</sup> | 2 <sup>nd</sup> |          | 1 <sup>st</sup> | 2 <sup>nd</sup> | 3 <sup>rd</sup> | 1 <sup>st</sup> | 2 <sup>nd</sup> | 1 <sup>st</sup> | 2 <sup>nd</sup> |    |    |
| IO0 | VSYNC        |                 |                 |        | CS      |           |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| IO1 | HSYNC        |                 |                 |        | RD      |           |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| IO2 | DCLK         |                 |                 |        | WR      |           |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| IO3 | DE           |                 |                 |        | RS      |           |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D23 | R7           |                 |                 | CKN    |         | D23       | R5              | R5              | B5              | G5              | R5              |                 | R5              | B5       | R4              |                 |                 |                 |                 |                 |                 |    |    |
| D22 | R6           |                 |                 | CKP    |         | D22       | R4              | R4              | B4              | G4              | R4              |                 | R4              | B4       | R3              |                 |                 |                 |                 |                 |                 |    |    |
| D21 | R5           |                 |                 |        |         | D21       | R3              | R3              | B3              | G3              | R3              |                 | R3              | B3       | R2              |                 |                 |                 |                 |                 |                 |    |    |
| D20 | R4           |                 |                 |        |         | D20       | R2              | R2              | B2              | G2              | R2              |                 | R2              | B2       | R1              |                 |                 |                 |                 |                 |                 |    |    |
| D19 | R3           |                 |                 |        |         | D19       | R1              | R1              | B1              | G1              | R1              |                 | R1              | B1       | R0              |                 |                 |                 |                 |                 |                 |    |    |
| D18 | R2           |                 |                 |        |         | D18       | R0              | R0              | B0              | G0              | R0              |                 | R0              | B0       | G5              |                 |                 |                 |                 |                 |                 |    |    |
| D17 | R1           |                 |                 |        |         | D17       |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D16 | R0           |                 |                 |        |         | D16       |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D15 | G7           |                 |                 |        |         | D15       | G5              |                 |                 |                 |                 |                 |                 |          | G4              |                 |                 |                 |                 |                 |                 |    |    |
| D14 | G6           |                 |                 |        |         | D14       | G4              |                 |                 |                 |                 |                 |                 |          | G3              |                 |                 |                 |                 |                 |                 |    |    |
| D13 | G5           |                 |                 |        |         | D13       | G3              |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D12 | G4           | D17             | D27             | D37    | D7      | D12       | G2              | G5              | R5              | B5              | G5              | B5              | G5              |          |                 | G2              | R5              | G5              | B5              | R4              | G2              | R5 | G2 |
| D11 | G3           | D16             | D26             | D36    | D6      | D11       | G1              | G4              | R4              | B4              | G4              | B4              | G4              |          |                 | G1              | R4              | G4              | B4              | R3              | G1              | R4 | G1 |
| D10 | G2           | D15             | D25             | D35    | D5      | D10       | G0              | G3              | R3              | B3              | G3              | B3              | G3              |          |                 | G0              | R3              | G3              | B3              | R2              | G0              | R3 | G0 |
| D9  | G1           |                 |                 |        |         | D9        |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D8  | G0           |                 |                 |        |         | D8        |                 |                 |                 |                 |                 |                 |                 |          |                 |                 |                 |                 |                 |                 |                 |    |    |
| D7  | B7           | D14             | D24             | D34    | D4      | D7        | B5              | G2              | R2              | B2              | G2              | B2              | G2              |          |                 | B4              | R2              | G2              | B2              | R1              | B4              | R2 | B5 |
| D6  | B6           | D13             | D23             | D33    | D3      | D6        | B4              | G1              | R1              | B1              | G1              | B1              | G1              |          |                 | B3              | R1              | G1              | B1              | R0              | B3              | R1 | B4 |

|    |    |     |     |     |    |    |    |    |    |    |    |    |    |  |    |    |    |    |    |    |    |    |
|----|----|-----|-----|-----|----|----|----|----|----|----|----|----|----|--|----|----|----|----|----|----|----|----|
| D5 | B5 | D12 | D22 | D32 | D2 | D5 | B3 | G0 | R0 | B0 | G0 | B0 | G0 |  | B2 | R0 | G0 | B0 | G5 | B2 | R0 | B3 |
| D4 | B4 | D11 | D21 | D31 | D1 | D4 | B2 |    |    |    |    |    |    |  | B1 |    |    |    | G4 | B1 | G5 | B2 |
| D3 | B3 | D10 | D20 | D30 | D0 | D3 | B1 |    |    |    |    |    |    |  | B0 |    |    |    | G3 | B0 | G4 | B1 |
| D2 | B2 |     |     |     |    | D2 | B0 |    |    |    |    |    |    |  |    |    |    |    | G3 | B0 |    |    |
| D1 | B1 |     |     |     |    | D1 |    |    |    |    |    |    |    |  |    |    |    |    |    |    |    |    |
| D0 | B0 |     |     |     |    | D0 |    |    |    |    |    |    |    |  |    |    |    |    |    |    |    |    |

For parallel RGB, the data of LCD is high-aligned. The correspondence is as follows.

| LCD I/O  | Parallel RGB |        |
|----------|--------------|--------|
|          | RGB565       | RGB666 |
| LCD0_D23 | R4           | R5     |
| LCD0_D22 | R3           | R4     |
| LCD0_D21 | R2           | R3     |
| LCD0_D20 | R1           | R2     |
| LCD0_D19 | R0           | R1     |
| LCD0_D18 | -            | R0     |
| LCD0_D15 | G5           | G5     |
| LCD0_D14 | G4           | G4     |
| LCD0_D13 | G3           | G3     |
| LCD0_D12 | G2           | G2     |
| LCD0_D11 | G1           | G1     |
| LCD0_D10 | G0           | G0     |
| LCD0_D7  | B4           | B5     |
| LCD0_D6  | B3           | B4     |
| LCD0_D5  | B2           | B3     |
| LCD0_D4  | B1           | B2     |
| LCD0_D3  | B0           | B1     |
| LCD0_D2  | -            | B0     |

The multiplex relationship between LCD I/O and LVDS is shown as follows.

|          |           |
|----------|-----------|
| LCD0_DE  | LVDS1_D3N |
| LCD0_CLK | LVDS1_D3P |
| LCD0_D23 | LVDS1_CKN |
| LCD0_D22 | LVDS1_CKP |
| LCD0_D21 | LVDS1_D2N |
| LCD0_D20 | LVDS1_D2P |
| LCD0_D19 | LVDS1_D1N |
| LCD0_D18 | LVDS1_D1P |
| LCD0_D15 | LVDS1_D0N |
| LCD0_D14 | LVDS1_D0P |
| LCD0_D13 | LVDS0_D3N |
| LCD0_D12 | LVDS0_D3P |

|          |           |
|----------|-----------|
| LCD0_D11 | LVDS0_CKN |
| LCD0_D10 | LVDS0_CKP |
| LCD0_D7  | LVDS0_D2N |
| LCD0_D6  | LVDS0_D2P |
| LCD0_D5  | LVDS0_D1N |
| LCD0_D4  | LVDS0_D1P |
| LCD0_D3  | LVDS0_D0N |
| LCD0_D2  | LVDS0_D0P |

#### 6.1.3.1.2. HV Interface (Sync+DE mode)

HV I/F is also known as Sync + DE mode, which is widely used in TFT LCD module for PMP/MP4 application.

**Table 6- 2. HV Panel Signals**

| Signal   | Description                                  | Type |
|----------|----------------------------------------------|------|
| Vsync    | Vertical sync, indicates one new frame       | O    |
| Hsync    | Horizontal sync, indicates one new scan line | O    |
| DCLK     | Dot clock, pixel data are sync by this clock | O    |
| DE       | LCD data enable                              | O    |
| D[23..0] | 24-bit RGB output from input FIFO for panel  | O    |

The timing diagram of HV interface is as follows.



Figure 6- 2. HV Interface Vertical Timing



Figure 6- 3. HV Interface Horizontal Timing

#### 6.1.3.1.3. BT656 Interface

In HV serial YUV output mode, its timing is BT656 compatible. SAV adds right before active area every line; EAV adds right after active area every line.

Table 6- 3. BT656 Panel Signals

| Signal    | Description  | Type |
|-----------|--------------|------|
| DCLK      | Clock signal | O    |
| DATA[7:0] | Data signal  | O    |

Its logic is:

F = "0" for Field 1 F = "1" for Field 2

V = "1" during vertical blanking

H = "0" at SAV H = "1" at EAV

P3-P0 = protection bits

$$P3 = V \oplus H$$

$$P2 = F \oplus H$$

$$P1 = F \oplus V$$

$$P0 = F \oplus V \oplus H$$

Where  $\oplus$  represents the exclusive-OR function

The 4 byte SAV/EAV sequence is as follows.

**Table 6- 4. EAV and SAV Sequence**

|                    | 8-bit Data |    |    |    |    |    |    |    | 10-bit Data |    |
|--------------------|------------|----|----|----|----|----|----|----|-------------|----|
|                    | D9(MSB)    | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1          | D0 |
| <b>preamble</b>    | 1          | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1           | 1  |
|                    | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  |
|                    | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  |
| <b>Status word</b> | 1          | F  | V  | H  | P3 | P2 | P1 | P0 | 0           | 0  |

#### 6.1.3.1.4. i8080 Interface

i8080 I/F LCD panel is most common interface for small size, low resolution LCD panels. CPU control signals are active low.

**Table 6- 5. CPU Panel Signals**

| Signal   | Description                                      | Type |
|----------|--------------------------------------------------|------|
| CS       | Chip select, active low                          | O    |
| WR       | Write strobe, active low                         | O    |
| RD       | Read strobe, active low                          | O    |
| A1       | Address bit, controlled by "LCD_CPU1/F" BIT26/25 | O    |
| D[23..0] | Digital RGB output signal                        | I/O  |

The following figure relationship between basic timing and CPU timing. WR is 180° delay of DCLK; CS is active when pixel data is valid; RD is always set to 1; A1 is set by "LCD\_CPU1/F".



Figure 6- 4. i8080 Interface Timing

When CPU I/F is in IDLE state, it can generate WR/RD timing by setting “**Lcd\_CPUIF**”. CS strobe is one DCLK width, WR/RD strobe is half DCLK width.

#### 6.1.3.1.5. LVDS Interface

Table 6- 6. LVDS Panel Signals

| External Signal | Description                         | Type |
|-----------------|-------------------------------------|------|
| CKP             | The positive port of clock          | O    |
| CKN             | The negative port of clock          | O    |
| D0P             | The positive port of data channel 0 | O    |
| D0N             | The negative port of data channel 0 | O    |
| D1P             | The positive port of data channel 1 | O    |
| D1N             | The negative port of data channel 1 | O    |
| D2P             | The positive port of data channel 2 | O    |
| D2N             | The negative port of data channel 2 | O    |
| D3P             | The positive port of data channel 3 | O    |
| D3N             | The negative port of data channel 3 | O    |

The following figures show the timing of LVDS interface.



**Figure 6- 5. LVDS Single Link JEDIA Mode Interface Timing**



**Figure 6- 6. LVDS Single Link NS Mode Interface Timing**



Figure 6-7. LVDS Dual Link NS Mode Interface Timing

#### 6.1.3.2. Clock Sources

The following table describes the clock sources of TCON\_LCD. Table 6-7 describes the clock sources of TCON\_LCD.

Table 6-7. TCON\_LCD Clock Sources

| Clock Sources  | Description                                        |
|----------------|----------------------------------------------------|
| PLL_VIDEO0(4X) | Video PLL Clock, and the default value is 1188 MHz |
| PLL_VIDEO1(4X) | Video PLL Clock, and the default value is 1188 MHz |
| PLL_VIDEO2(4X) | Video PLL Clock, and the default value is 1188 MHz |
| PLL_VIDEO3(4X) | Video PLL Clock, and the default value is 1188 MHz |

|               |                                                   |
|---------------|---------------------------------------------------|
| PLL_PERIO(2X) | PERIO PLL Clock, and the default value is 1.2 GHz |
|---------------|---------------------------------------------------|

### 6.1.3.3. RGB Gamma Correction

Function: This module correct the RGB input data of DE.

A 256\*8\*3 Byte register file is used to store the gamma table. The following is the layout.

**Table 6- 8. RGB Gamma Correction**

| Offset | Value                               |
|--------|-------------------------------------|
| 0x400  | { B0[7:0], G0[7:0], R0[7:0] }       |
| 0x404  | { B1[7:0], G1[7:0], R1[7:0] }       |
| .....  | .....                               |
| 0x7FC  | { B255[7:0], G255[7:0], R255[7:0] } |

### 6.1.3.4. CEU Module

This module enhances color data from DE.

$$R' = Rr * R + Rg * G + Rb * B + Rc$$

$$G' = Gr * R + Gg * G + Gb * B + Gc$$

$$B' = Br * R + Bg * G + Bb * B + Bc$$



#### NOTE

|                                    |     |                 |
|------------------------------------|-----|-----------------|
| Rr, Rg, Rb, Gr, Gg, Gb, Br, Bg, Bb | s13 | (-16, 16)       |
| Rc, Gc, Bc                         | s19 | (-16384, 16384) |
| R, G, B                            | u8  | [0-255]         |

R' has the range of [Rmin ,Rmax]

G' has the range of [Rmin ,Rmax]

B' has the range of [Rmin ,Rmax]

### 6.1.3.5. CMAP Module

Function: This module map color data from DE.

Every 4 input pixels are as a unit. A unit is divided into 12 bytes. The output byte can select one of those 12 bytes.

Note that even line and odd line can be different, and the output can be 12 bytes(4 pixels) or reduce to 6 bytes(2 pixels).



Figure 6- 8. CMAP Module

#### 6.1.3.6. FRM Module



Figure 6- 9. FRM Module

#### 6.1.4. Programming Guidelines

##### 6.1.4.1. HV Mode Configuration Process



Figure 6- 10. HV Mode Initial Process

### (1) Parallel RGB

#### Step1: Select HV interface type

Configure LCD\_CTL\_REG[LCD\_IF](reg0x40) to 0 to select HV(Sync+DE) mode, and configure LCD\_HV\_IF\_REG[HV\_MODE](reg0x58) to 0 to select 24bit/1cycle parallel mode.

```

lcd_dev[sel]->lcd_ctl.lcd_if = HV(Sync+DE);
lcd_dev[sel]->lcd_ctl.src_sel = src; //src = DE/color/grayscale/...
lcd_dev[sel]->lcd_hv_ctl.hv_mode = 24-bit/1cycle parallel mode;
    
```

#### Step2: Clock configuration



##### NOTE

- In parallel RGB mode, the displayed pixel clock(pixel\_CLK) is required to be consistent with the DCLK, the pixel\_clk(pixel\_clk=Ht\*Vt\*frame rate) is decided by external LCD.
- When using phase adjustment function, the LCD\_IO\_POL\_REG.DCLK\_SEL(reg0x88) selects dclk0~2 of different phase, and LCD\_IO\_POL\_REG.IO2\_INV can achieve 180°phase delay.

Configure corresponding frequency by setting PLL\_VIDEO0/1/2/3 register, and configure TCON LCD0 Clock register.

Configure internal frequency division of TCON\_LCD. Based on clock source of TCON and DCLK clock ratio, configure LCD\_DCLK\_REG[LCD\_DCLK\_DIV]. If using phase adjustment function, LCD\_DCLK\_REG[LCD\_DCLK\_EN] needs be set, usually is 0xf. When the dclk1 and dclk2 in LCD\_DCLK\_REG[LCD\_DCLK\_EN] are used, the value of LCD\_DCLK\_REG[LCD\_DCLK\_DIV] needs no less than 6.

```

lcd_dev[sel]->lcd_dclk.dclk_en = en;
lcd_dev[sel]->lcd_dclk.dclk_div = div;
    
```

#### Step3: Set sequence parameters

The sequence parameters include x,ht,hbp,hspw,y,vt,vbp,vspw, and correspond to LCD\_BASE\_REG in reg0x48~0x54.

Note that hbp includes hspw, and vbp includes vspw. And LCD\_BASE2\_REG.VT needs be set to the twice of the actual value.

```

lcd_dev[sel]->lcd_basic0.x = x-1;
lcd_dev[sel]->lcd_basic0.y = y-1;
lcd_dev[sel]->lcd_basic1.ht = ht-1;
lcd_dev[sel]->lcd_basic1.hbp = hbp-1;
lcd_dev[sel]->lcd_basic2.vt = vt*2;
lcd_dev[sel]->lcd_basic2.vbp = vbp-1;
lcd_dev[sel]->lcd_basic3.hspw = hspw-1;
lcd_dev[sel]->lcd_basic3.vspw = vspw-1;
    
```

#### Step4: Open IO output

Set the corresponding data IO enable and control signal IO enable of LCD\_IO\_TRI\_REG(reg0x8C) to 0 to start enable. Note that except the internal IO of TCON\_LCD, the external GPIO mapping needs to be set to LCD mode.

When some control signals require polarity reversal, it can realize by setting LCD\_IO\_POL\_REG.IO0~3\_INV(reg0x88).

#### Step5: Set and open interrupt function

The LCD\_GINT0\_REG(reg0x4) controls interrupt mode and flag, and the LCD\_GINT1\_REG(reg0x8) sets the interrupt line position of Line interrupt mode.

##### V interrupt:

```
lcd_dev[sel]->lcd_gint0.vb_en = 1;
```

##### Line interrupt:

```
lcd_dev[sel]->lcd_gint1.lcd_line_int_num = line;
```

```
lcd_dev[sel]->lcd_gint0.line_en = 1;
```

#### Step6: Open module enable

Enable LCD\_CTL\_REG.LCD\_EN(reg0x40) and LCD\_GCTL\_REG.LCD\_EN(reg0x00).

```
lcd_dev[sel]->lcd_ctl.lcd_en = 1;
```

```
lcd_dev[sel]->lcd_gctl.lcd_en = 1;
```

### (2) Serial RGB

The serial RGB mode is consistent with parallel RGB mode, the main difference is the definition of clock and the sequence of serial data. The difference is as follows.

#### Step1: Select HV interface type

Set LCD\_CTL\_REG.LCD\_IF(reg0x40) to 0 to select HV(Sync+DE) mode; set LCD\_HV\_IF\_REG.HV\_MODE(reg0x58) to select 8bit/3cycle RGB serial mode(RGB888), 8bit/4cycle Dummy RGB mode(DRGB) or 8bit/4cycle RGB Dummy mode(RGBD).

```
lcd_dev[sel]->lcd_ctl.lcd_if = HV(Sync+DE);
```

```
lcd_dev[sel]->lcd_ctl.src_sel = src; //src = DE/color/grayscale/...
```

```
lcd_dev[sel]->lcd_hv_ctl.hv_mode = Serial mode;
```

**Step2、Step3:** In serial RGB mode, DCLK is the transfer clock of each byte data. In the same resolution, pixel\_clk of serial RGB is three times of its clock in parallel RGB, and ht,hbp,hspw own the same conversion relation. When display is split into odd field and even field, LCD\_BASE2\_REG.VT needs not to be set to the twice of the actual value.

```
lcd_dev[sel]->lcd_basic2.vt = vt;
```

Set LCD\_HV\_IF\_REG.RGB888\_ODD\_ORDER/LCD\_HV\_IF\_REG.RGB888\_ODD\_EVEN to select RGB output sequence of the selected odd and even lines.

```
lcd_dev[lcd_sel]->lcd_hv_ctl.srgb_seq_even = seq_even;
```

```
lcd_dev[lcd_sel]->lcd_hv_ctl.srgb_seq_odd = seq_odd;
```

#### 6.1.4.2. LVDS Mode Configuration Process



Figure 6-11. LVDS Mode Configuration Process

The LVDS interface configuration process is similar to the parallel mode of HV mode, and adds the digital/analog configuration of LVDS interface.

**Step1:** Same as in step1 of parallel mode

**Step2:** Clock configuration



##### NOTE

In parallel mode, the displayed pixel clock(pixel\_CLK) is required to be consistent with the DCLK,  $\text{pixel\_clk} = \text{Ht} * \text{Vt} * \text{frame rate}$ .

- Configure LCD\_DCLK\_REG.LCD\_DCLK\_DIV(reg0x44) to 7 after DCLK is determined;
- Configure the PLL clock in CCU based on proportional relationship;
- Release the LVDS reset of TCON\_LCD\_BGR\_REG;
- Other configurations remain unchanged.

```
lcd_dev[sel]->lcd_dclk.dclk_en = en;
lcd_dev[sel]->lcd_dclk.dclk_div = 7;
```

**Step3:** Same as in step3 of parallel mode

**Step4:** Same as in step4 of parallel mode

**Step5: LVDS digital logic configuration**

Includes clock source select of module, LVDS link number, data mode and bit width configuration.

- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_CLK\_SEL(reg0x84) to set LCD CLK;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_LINK to set the required LVDS port number;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_MODE to set JEDIA and NS mode;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_BITWIDTH to select 24-bit or 18-bit width;
- Lastly configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_EN to start LVDS mode.

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_link = link_num-1;
lcd_dev[sel]->lcd_lvds_ctl.lvds_mode = mode;
lcd_dev[sel]->lcd_lvds_ctl.lvds_bitwidth = bitwidth;
lcd_dev[sel]->lcd_lvds_ctl.lvds_clk_sel = clk_src;
lcd_dev[sel]->lcd_lvds_ctl.lvds_en = 1;
```

**NOTE**

If configuring the same source data output mode of dual link, except the reg0x84 register of TCON\_LCD0 needs be configured, the LCD\_LVDS\_IF\_REG.LCD\_LVDS\_CLK\_SEL, LCD\_LVDS\_IF\_REG.LCD\_LVDS\_LINK, LCD\_LVDS\_IF\_REG.LCD\_LVDS\_MODE, and LCD\_LVDS\_IF\_REG.LCD\_LVDS\_BITWIDTH of the reg0x244 register need be configured.

**Step6: LVDS controller configuration****NOTE**

The TCON LCD0 PHY0 is controlled by COMBO\_PHY\_REG(reg0x1110, reg0x1114). The TCON LCD0 PHY1 is controlled by LCD\_LVDS0\_ANA\_REG(reg0x220).

**For PHY0:**

- Configure the reg\_verf1p6(differential mode voltage) in reg0x1114 to 4;
- Configure the reg\_vref0p8 reg0x1114(common mode voltage) in reg0x1114 to 3;
- Start en\_cp, en\_mipi, en\_lvds, and en\_combaldo in reg0x1110, in turn.

**For PHY1:**

The LVDS analog configuration process is to start clock and data channel, and set the common mode and differential mode voltage, and start module power.

- Configure LVDS\_HPREN\_DRVC and LVDS\_HPREN\_DRV. When LVDS signal is 18-bit, LVDS\_HPREN\_DRV=0x7; when LVDS signal is 24-bit, LVDS\_HPREN\_DRV=0xF;
- Configure LVDS0\_REG\_C(differential mode voltage) to 4;
- Configure LVDS0\_REG\_V(common mode voltage) to 3;
- Lastly, start module voltage, and enable EN\_LVDS and EN\_24M.

**NOTE**

When the same source data output of dual link needs be configured, then the LVDS\_DUAL\_CHANNEL\_SRC\_SEL needs be configured to 1.

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_drvd = 0x7; //18bit=0x7, 24bit=0xf  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_drvc = 1;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.diff_level = diff;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.com_level = com;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.dual_src = link_src;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_24M = 1;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_lvds = 1;  
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_mb = 1;
```

**Step7: Same as in step5 of parallel mode****Step8: Same as in step6 of parallel mode**

#### **6.1.4.3. i8080 Mode Configuration Process**



**Figure 6- 12. i8080 Mode Initial Process**

**Step1:** Select i8080 interface type.

**Step2:** The step is the same as HV mode, but pulse adjustment function is invalid.

**Step3:** The step is the same as HV mode. When using TRI mode, it is best to configure LCD timing parameters in HV mode , or a handful of functions such as CMAP will not be able to apply.

**Step4:** The step is the same as HV mode.

**Step5:** Select type and operating mode of i8080, the operating mode includes TRI mode and AUTO mode, and the two operating modes are different.

## -TRI mode-

#### **Step6:** Open TRI FIFO switch, and TRI mode function.

**Step7:** Set parameters of TRI mode, including block size, block space and block number.



## **NOTE**

**When output interface is parallel mode, then the setting value of block space parameter is not less than 20.**

**When output interface is 2 cycle serial mode, then the setting value of block space parameter is not less than 40.**

**When output interface is 3 cycle serial mode, then the setting value of block space parameter is not less than 60.**

**When output interface is 4 cycle serial mode, then the setting value of block space parameter is not less than 80.**

**Step8:** Set the tri interrupt or counter interrupt. When using the two interrupts, mainly in the interrupt service function the tri start operation need be operated (the bit1 of LCD\_CPU\_IF\_REG is set to "1"). If using TE trigger interrupt, you select the external input pin as a trigger signal, the 24-bit for offset 0x8C register is set to "1", to open up input of pad.

**Step9:** Open interrupt total switch.

**Step10:** Open interrupt total enable.

**Step11:** Operate tri start operation(the bit1 of LCD CPU IF REG is set to"1").

-Auto mode-

**Step6:** Set and open V interrupt or Line interrupt, the step is the same as HV mode.

**Step7:** Open module total enable.

#### 6.1.4.4. MIPI DSI Notes

The requirements on MIPI DSI mode are as follows.

- (1). When using MIPI DSI as display interface, the data clk of TCON needs be started firstly.
- (2). When it is used with DSI video mode, the setting of block space needs to meet the following relationship.



Figure 6- 13. MIPI DSI Video Mode Data Timing

#### 6.1.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| TCON_LCD0   | 0x06511000   |

| Register Name    | Offset        | Description                          |
|------------------|---------------|--------------------------------------|
| LCD_GCTL_REG     | 0x0000        | LCD Global Control Register          |
| LCD_GINT0_REG    | 0x0004        | LCD Global Interrupt Register0       |
| LCD_GINT1_REG    | 0x0008        | LCD Global Interrupt Register1       |
| LCD_FRM_CTL_REG  | 0x0010        | LCD FRM Control Register             |
| LCD_FRM_SEED_REG | 0x0014+N*0x04 | LCD FRM Seed Register(N=0,1,2,3,4,5) |
| LCD_FRM_TAB_REG  | 0x002C+N*0x04 | LCD FRM Table Register(N=0,1,2,3)    |
| LCD_3D_FIFO_REG  | 0x003C        | LCD 3D FIFO Register                 |
| LCD_CTL_REG      | 0x0040        | LCD Control Register                 |
| LCD_DCLK_REG     | 0x0044        | LCD Data Clock Register              |
| LCD_BASIC0_REG   | 0x0048        | LCD Basic Timing Register0           |
| LCD_BASIC1_REG   | 0x004C        | LCD Basic Timing Register1           |

|                       |               |                                        |
|-----------------------|---------------|----------------------------------------|
| LCD_BASIC2_REG        | 0x0050        | LCD Basic Timing Register2             |
| LCD_BASIC3_REG        | 0x0054        | LCD Basic Timing Register3             |
| LCD_HV_IF_REG         | 0x0058        | LCD HV Panel Interface Register        |
| LCD_CPU_IF_REG        | 0x0060        | LCD CPU Panel Interface Register       |
| LCD_LVDS_IF_REG       | 0x0084        | LCD LVDS Configure Register            |
| LCD_IO_POL_REG        | 0x0088        | LCD IO Polarity Register               |
| LCD_IO_TRI_REG        | 0x008C        | LCD IO Control Register                |
| LCD_DEBUG_REG         | 0x00FC        | LCD Debug Register                     |
| LCD_CEU_CTL_REG       | 0x0100        | LCD CEU Control Register               |
| LCD_CEU_COEF_MUL_REG  | 0x0110+N*0x04 | LCD CEU Coefficient Register0(N=0~10)  |
| LCD_CEU_COEF_ADD_REG  | 0x011C+N*0x10 | LCD CEU Coefficient Register1(N=0,1,2) |
| LCD_CEU_COEF_RANG_REG | 0x0140+N*0x04 | LCD CEU Coefficient Register2(N=0,1,2) |
| LCD_CPU_TRI0_REG      | 0x0160        | LCD CPU Panel Trigger Register0        |
| LCD_CPU_TRI1_REG      | 0x0164        | LCD CPU Panel Trigger Register1        |
| LCD_CPU_TRI2_REG      | 0x0168        | LCD CPU Panel Trigger Register2        |
| LCD_CPU_TRI3_REG      | 0x016C        | LCD CPU Panel Trigger Register3        |
| LCD_CPU_TRI4_REG      | 0x0170        | LCD CPU Panel Trigger Register4        |
| LCD_CPU_TRI5_REG      | 0x0174        | LCD CPU Panel Trigger Register5        |
| LCD_CMAP_CTL_REG      | 0x0180        | LCD Color Map Control Register         |
| LCD_CMAP_ODD0_REG     | 0x0190        | LCD Color Map Odd Line Register0       |
| LCD_CMAP_ODD1_REG     | 0x0194        | LCD Color Map Odd Line Register1       |
| LCD_CMAP_EVEN0_REG    | 0x0198        | LCD Color Map Even Line Register0      |
| LCD_CMAP_EVEN1_REG    | 0x019C        | LCD Color Map Even Line Register1      |
| LCD_SAFE_PERIOD_REG   | 0x01F0        | LCD Safe Period Register               |
| LCD_LVDS0_ANA_REG     | 0x0220        | LCD LVDS Analog Register 0             |
| LCD_FSYNC_GEN_DLY_REG | 0x0240        | Fsync Active Time Register             |
| LCD_GAMMA_TABLE_REG   | 0x0400-0x07FF | LCD Gamma Table Register               |

### 6.1.6. Register Description

#### 6.1.6.1. 0x0000 LCD Global Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: LCD_GCTL_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | LCD_EN<br>0: Disable<br>1: Enable<br>When it is disabled, the module will be reset to idle state. |
| 30             | R/W        | 0x0         | LCD_GAMMA_EN<br>0: Disable<br>1: Enable<br>Enable the Gamma correction function.                  |
| 29:0           | /          | /           | /                                                                                                 |

#### 6.1.6.2. 0x0004 LCD Global Interrupt Register0(Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: LCD_GINT0_REG                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31             | R/W        | 0x0         | LCD_VB_INT_EN<br>0: Disable<br>1: Enable<br>Enable the Vb interrupt.                                                |
| 30             | /          | /           | /                                                                                                                   |
| 29             | R/W        | 0x0         | LCD_LINE_INT_EN<br>0: Disable<br>1: Enable<br>Enable the line interrupt.                                            |
| 28             | /          | /           | /                                                                                                                   |
| 27             | R/W        | 0x0         | LCD_TRI_FINISH_INT_EN<br>0: Disable<br>1: Enable<br>Enable the trigger finish interrupt.                            |
| 26             | R/W        | 0x0         | LCD_TRI_COUNTER_INT_EN<br>0: Disable<br>1: Enable<br>Enable the trigger counter interrupt.                          |
| 25:16          | /          | /           | /                                                                                                                   |
| 15             | R/WOC      | 0x0         | LCD_VB_INT_FLAG<br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it.                  |
| 14             | /          | /           | /                                                                                                                   |
| 13             | R/WOC      | 0x0         | LCD_LINE_INT_FLAG<br>Trigger when SY0 matched the current LCD scan line.<br>Write 0 to clear it.                    |
| 12             | /          | /           | /                                                                                                                   |
| 11             | R/WOC      | 0x0         | LCD_TRI_FINISH_INT_FLAG<br>Trigger when cpu trigger mode finished.<br>Write 0 to clear it.                          |
| 10             | R/WOC      | 0x0         | LCD_TRI_COUNTER_INT_FLAG<br>Trigger when tri counter reached this value.<br>Write 0 to clear it.                    |
| 9              | R/WOC      | 0x0         | LCD_TRI_UNDERFLOW_FLAG<br>Only used in DSI video mode, tri when sync by DSI but not finish.<br>Write 0 to clear it. |
| 8:0            | /          | /           | /                                                                                                                   |

#### 6.1.6.3. 0x0008 LCD Global Interrupt Register1(Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: LCD_GINT1_REG                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:28          | /          | /           | /                                                                                                                                                                                               |
| 27:16          | R/W        | 0x0         | LCD_LINE_INT_NUM<br>Scan line for LCD line trigger(including inactive lines)<br>Setting it for the specified line of trigger0.<br><b>Note: SY0 is writable only when LINE_TRGO is disabled.</b> |
| 15:0           | /          | /           | /                                                                                                                                                                                               |

#### 6.1.6.4. 0x0010 LCD FRM Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: LCD_FRM_CTL_REG                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31             | R/W        | 0x0         | LCD_FRM_EN<br>0:Disable<br>1:Enable<br>Enable the dither function.                                                                                           |
| 30:7           | /          | /           | /                                                                                                                                                            |
| 6              | R/W        | 0x0         | LCD_FRM_MODE_R<br>0: 6-bit frm output<br>1: 5-bit frm output<br>The R component output bits are in dither function.                                          |
| 5              | R/W        | 0x0         | LCD_FRM_MODE_G<br>0: 6-bit frm output<br>1: 5-bit frm output<br>The G component output bits are in dither function.                                          |
| 4              | R/W        | 0x0         | LCD_FRM_MODE_B<br>0: 6-bit frm output<br>1: 5-bit frm output<br>The B component output bits are in dither function.                                          |
| 3:2            | /          | /           | /                                                                                                                                                            |
| 1:0            | R/W        | 0x0         | LCD_FRM_TEST<br>00: FRM<br>01: half 5-/6-bit, half FRM<br>10: half 8-bit, half FRM<br>11: half 8-bit, half 5-/6-bit<br>Set the test mode of dither function. |

#### 6.1.6.5. 0x0014+N\*0x04 LCD FRM Seed Register(Default Value: 0x0000\_0000)

| Offset: 0x0014+N*0x04(N=0~5) |            |             | Register Name: LCD_FRM_SEED_REG                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                             |
| 31:25                        | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                       |
| 24:0                         | R/W        | 0x0         | <p>SEED_VALUE<br/>                     N=0: Pixel_Seed_R<br/>                     N=1: Pixel_Seed_G<br/>                     N=2: Pixel_Seed_B<br/>                     N=3: Line_Seed_R<br/>                     N=4: Line_Seed_G<br/>                     N=5: Line_Seed_B<br/>                     Set the seed used in dither function.<br/> <b>Note: Avoid setting it to 0</b></p> |

#### 6.1.6.6. 0x002C+N\*0x04 LCD FRM Table Register(Default Value: 0x0000\_0000)

| Offset: 0x002C+N*0x04(N=0~3) |            |             | Register Name: LCD_FRM_TAB_REG                                                                                                                                                                                                                                                                                            |
|------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                               |
| 31:0                         | R/W        | 0x0         | <p>FRM_TABLE_VALUE<br/>                     Set the data used in dither function.<br/>                     Usually set as follow:<br/>                     Table0 = 0x01010000<br/>                     Table1 = 0x15151111<br/>                     Table2 = 0x57575555<br/>                     Table3 = 0x7F7F7777</p> |

#### 6.1.6.7. 0x003C LCD 3D FIFO Register(Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: LCD_3D_FIFO_REG                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31             | R/W        | 0x0         | <p>3D_FIFO_BIST_EN<br/>                     0: Disable<br/>                     1: Enable<br/>                     Enable the 3rd fifo bist test function.</p>                        |
| 30:14          | /          | /           | /                                                                                                                                                                                     |
| 13:4           | R/W        | 0x0         | <p>3D_FIFO_HALF_LINE_SIZE<br/>                     The number of data in half line=3D_FIFO_HALF_LINE_SIZE+1<br/>                     Only valid when 3D_FIFO_SETTING is set as 2.</p> |
| 3:2            | /          | /           | /                                                                                                                                                                                     |
| 1:0            | R/W        | 0x0         | <p>3D_FIFO_SETTING<br/>                     Set the work mode of 3D FIFO.</p>                                                                                                         |

|  |  |  |                                                                                        |
|--|--|--|----------------------------------------------------------------------------------------|
|  |  |  | 00: Bypass<br>01: Used as normal FIFO<br>10: Used as 3D interlace FIFO<br>11: Reserved |
|--|--|--|----------------------------------------------------------------------------------------|

#### 6.1.6.8. 0x0040 LCD Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: LCD_CTL_REG                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31             | R/W        | 0x0         | <b>LCD_EN</b><br>0: Disable<br>1: Enable<br>It executes at the beginning of the first blank line of LCD timing.                                                         |
| 30:26          | /          | /           | /                                                                                                                                                                       |
| 25:24          | R/W        | 0x0         | <b>LCD_IF</b><br>00: HV(Sync+DE)<br>01: 8080 I/F<br>1x: Reserved<br>Set the interface type of LCD controller.                                                           |
| 23             | R/W        | 0x0         | <b>LCD_RB_SWAP</b><br>0: Default<br>1: Swap RED and BLUE data at FIFO1<br>Enable the function to swap red data and blue data in FIFO1.                                  |
| 22             | /          | /           | /                                                                                                                                                                       |
| 21             | R/W        | 0x0         | <b>LCD_FIFO1_RST</b><br>Writing 1 and then 0 to this bit will reset FIFO 1<br><b>Note: 1 holding time must more than 1 DCLK.</b>                                        |
| 20             | R/W        | 0x0         | <b>LCD_INTERLACE_EN</b><br>0:Disable<br>1:Enable<br>This flag is valid only when LCD_EN == 1                                                                            |
| 19:9           | /          | /           | /                                                                                                                                                                       |
| 8:4            | R/W        | 0x0         | <b>LCD_START_DELAY</b><br>The unit of delay is T_line.<br>Valid only when LCD_EN == 1                                                                                   |
| 3              | /          | /           | /                                                                                                                                                                       |
| 2:0            | R/W        | 0x0         | <b>LCD_SRC_SEL</b><br>000: DE<br>001: Color Check<br>010: Grayscale Check<br>011: Black by White Check<br>100: Test Data all 0<br>101: Test Data all 1<br>110: Reserved |

|  |  |  |                     |
|--|--|--|---------------------|
|  |  |  | 111: Gridding Check |
|--|--|--|---------------------|

#### 6.1.6.9. 0x0044 LCD Data Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: LCD_DCLK_REG                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:28          | R/W        | 0x0         | LCD_DCLK_EN<br>LCD clock enable<br>0000: dclk_en = 0; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 0;<br>0001: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 0;<br>0010: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 1;<br>0011: dclk_en = 1; dclk1_en = 1; dclk2_en = 0; dclkm2_en = 0;<br>0101: dclk_en = 1; dclk1_en = 0; dclk2_en = 1; dclkm2_en = 0;<br>1111: dclk_en = 1; dclk1_en = 1; dclk2_en = 1; dclkm2_en = 1;<br>Others:Reserved |
| 27:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6:0            | R/W        | 0x0         | LCD_DCLK_DIV<br>Tdclk = Tsclk / DCLKDIV<br><b>Note: If dclk1&amp;dclk2 used, DCLKDIV &gt;=6. If dclk only, DCLKDIV &gt;=1</b>                                                                                                                                                                                                                                                                                                                            |

#### 6.1.6.10. 0x0048 LCD Basic Timing Register0(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: LCD_BASIC0_REG |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:28          | /          | /           | /                             |
| 27:16          | R/W        | 0x0         | X<br>Panel width is X+1       |
| 15:12          | /          | /           | /                             |
| 11:0           | R/W        | 0x0         | Y<br>Panel height is Y+1      |

#### 6.1.6.11. 0x004C LCD Basic Timing Register1(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: LCD_BASIC1_REG                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:29          | /          | /           | /                                                                                            |
| 28:16          | R/W        | 0x0         | HT<br>Thcycle = (HT+1) * Tdclk<br>Computation:<br>1) parallel: HT = X + BLANK<br>Limitation: |

|       |     |     |                                                                                                                                  |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1) parallel: HT >= (HBP +1) + (X+1) +2<br>2) serial 1: HT >= (HBP +1) + (X+1) *3+2<br>3) serial 2: HT >= (HBP +1) + (X+1) *3/2+2 |
| 15:12 | /   | /   | /                                                                                                                                |
| 11:0  | R/W | 0x0 | HBP<br>horizontal back porch (in dclk)<br>$Thbp = (HBP +1) * Tdclk$                                                              |

#### 6.1.6.12. 0x0050 LCD Basic Timing Register2(Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: LCD_BASIC2_REG                              |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:29          | /          | /           | /                                                          |
| 28:16          | R/W        | 0x0         | VT<br>TVT = (VT)/2 * Thsync<br>VT/2 >= (VBP+1 ) + (Y+1) +2 |
| 15:12          | /          | /           | /                                                          |
| 11:0           | R/W        | 0x0         | VBP<br>$Tvbp = (VBP +1) * Thsync$                          |

#### 6.1.6.13. 0x0054 LCD Basic Timing Register3(Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: LCD_BASIC3_REG                            |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:26          | /          | /           | /                                                        |
| 25:16          | R/W        | 0x0         | HSPW<br>$Thspw = (HSPW+1) * Tdclk$<br>HT> (HSPW+1)       |
| 15:10          | /          | /           | /                                                        |
| 9:0            | R/W        | 0x0         | VSPW<br>$Tvspw = (VSPW+1) * Thsync$<br>$VT/2 > (VSPW+1)$ |

#### 6.1.6.14. 0x0058 LCD HV Panel Interface Register(Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: LCD_HV_IF_REG                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:28          | R/W        | 0x0         | HV_MODE<br>0000: 24-bit/1cycle parallel mode<br>1000: 8-bit/3 cycle RGB serial mode(RGB888)<br>1010: 8-bit/4 cycle Dummy RGB(DRGB) |

|       |     |     |                                                                                                                                                                                |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1011: 8-bit/4 cycle RGB Dummy(RGBD)<br>1100: 8-bit/2 cycle YUV serial mode(CCIR656)<br>Set the HV mode of LCD controller.                                                      |
| 27:26 | R/W | 0x0 | RGB888_ODD_ORDER<br>00: R→G→B<br>01: B→R→G<br>10: G→B→R<br>11: R→G→B<br>Serial RGB888 mode output sequence at odd lines of the panel (line 1, 3, 5, 7...)                      |
| 25:24 | R/W | 0x0 | RGB888_EVEN_ORDER<br>00: R→G→B<br>01: B→R→G<br>10: G→B→R<br>11: R→G→B<br>Serial RGB888 mode output sequence at even lines of the panel (line 2, 4, 6, 8...)                    |
| 23:22 | R/W | 0x0 | YUV_SM<br>00: YUYV<br>01: YVYU<br>10: UYVY<br>11: VYUY<br>Serial YUV mode output sequence 2-pixel-pair of every scan line                                                      |
| 21:20 | R/W | 0x0 | YUV EAV/SAV F LINE DELAY<br>00:F toggle right after active video line<br>01: delay 2 line(CCIR PAL)<br>10: delay 3 line(CCIR NTSC)<br>11: reserved<br>Set the delay line mode. |
| 19    | R/W | 0x0 | CCIR_CSC_DIS<br>0: Enable<br>1: Disable<br>Only valid when HV mode is "1100".<br>Select '0' LCD convert source from RGB to YUV                                                 |
| 18:0  | /   | /   | /                                                                                                                                                                              |

#### 6.1.6.15. 0x0060 LCD CPU Panel Interface Register(Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: LCD_CPU_IF_REG                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:28          | R/W        | 0x0         | CPU_MODE<br>0000: 18-bit/256K mode<br>0010: 16-bit mode0<br>0100: 16-bit mode1 |

|       |       |     |                                                                                                                                                                                                         |
|-------|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |     | 0110: 16-bit mode2<br>1000: 16-bit mode3<br>1010: 9-bit mode<br>1100: 8-bit 256K mode<br>1110: 8-bit 65K mode<br>xxx1: 24-bit for DSI<br>Set the i8080 interface work mode.                             |
| 27    | /     | /   | /                                                                                                                                                                                                       |
| 26    | R/W   | 0x0 | DA<br>Pin A1 value in 8080 mode auto/flash states                                                                                                                                                       |
| 25    | R/W   | 0x0 | CA<br>Pin A1 value in 8080 mode WR/RD execute                                                                                                                                                           |
| 24    | /     | /   | /                                                                                                                                                                                                       |
| 23    | R     | 0x0 | WR_FLAG<br>Status of Write Operation<br>0: Write operation is finishing<br>1: Write operation is pending                                                                                                |
| 22    | R     | 0x0 | RD_FLAG<br>Status of Read Operation<br>0: Read operation is finishing<br>1: Read operation is pending                                                                                                   |
| 21:18 | /     | /   | /                                                                                                                                                                                                       |
| 17    | R/W   | 0x0 | AUTO<br>Auto Transfer Mode<br>If it is 1, all the valid data during this frame are written to panel.<br>This bit is sampled by Vsync.                                                                   |
| 16    | R/W   | 0x0 | FLUSH<br>Direct Transfer Mode<br>If it is enabled, FIFO1 is regardless of the HV timing, pixels data keep being transferred unless the input FIFO was empty.<br>Data output rate is controlled by DCLK. |
| 15:4  | /     | /   | /                                                                                                                                                                                                       |
| 3     | R/W   | 0x0 | TRIGGER_FIFO_BIST_EN<br>0: Disable<br>1: Enable<br>Entry addr is 0xFF8.                                                                                                                                 |
| 2     | R/W   | 0x0 | TRIGGER_FIFO_EN<br>0:Disable<br>1:Enable<br>Enable the trigger FIFO.                                                                                                                                    |
| 1     | R/W1S | 0x0 | TRIGGER_START<br>Write '1' to start a frame flush, writing '0' has no effect.<br>This flag indicated frame flush is running.<br>Software must write '1' only when this flag is '0'.                     |
| 0     | R/W   | 0x0 | TRIGGER_EN                                                                                                                                                                                              |

|  |  |  |                                                                           |
|--|--|--|---------------------------------------------------------------------------|
|  |  |  | 0: Trigger mode disable<br>1: Trigger mode enable<br>Enable trigger mode. |
|--|--|--|---------------------------------------------------------------------------|

#### 6.1.6.16. 0x0064 LCD CPU Panel Write Data Register(Default Value: 0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: LCD_CPU_WR_REG                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:24          | /          | /           | /                                                                       |
| 23:0           | W          | 0x0         | DATA_WR<br>Data write on 8080 bus, launch a write operation on 8080 bus |

#### 6.1.6.17. 0x0068 LCD CPU Panel Read Data Register0(Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: LCD_CPU_RD0_REG                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:24          | /          | /           | /                                                                          |
| 23:0           | R          | 0x0         | DATA_RD0<br>Data read on 8080 bus, launch a new read operation on 8080 bus |

#### 6.1.6.18. 0x006C LCD CPU Panel Read Data Register1(Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: LCD_CPU_RD1_REG                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:24          | /          | /           | /                                                                           |
| 23:0           | R          | 0x0         | DATA_RD1<br>Data read on 8080 bus, without a new read operation on 8080 bus |

#### 6.1.6.19. 0x0084 LCD LVDS Configure Register(Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: LCD_LVDS_IF_REG                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0           | LCD_LVDS_EN<br>0: Disable<br>1: Enable<br>Enable lvds interface                                   |
| 30             | R/W        | 0           | LCD_LVDS_LINK<br>0: Single link<br>1: Dual link<br>Select work single link mode or dual link mode |

|       |     |     |                                                                                                                                         |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
| 29    | R/W | 0x0 | LCD_LVDS_EVEN_ODD_DIR<br>0: Normal<br>1: Reverse<br>Set the order of even pixel and odd pixel.                                          |
| 28    | R/W | 0x0 | LCD_LVDS_DIR<br>0: Normal<br>1: Reverse<br>Set the lvds direction                                                                       |
| 27    | R/W | 0x0 | LCD LVDS MODE<br>0: NS mode<br>1: JEIDA mode<br>Set the LVDS data mode.                                                                 |
| 26    | R/W | 0x0 | LCD_LVDS_BIT_WIDTH<br>0: 24-bit<br>1: 18-bit                                                                                            |
| 25    | R/W | 0x0 | LCD_LVDS_DEBUG_EN<br>0: Disable<br>1: Enable                                                                                            |
| 24    | R/W | 0x0 | LCD_LVDS_DEBUG_MODE<br>0: Mode0 random data<br>1: Mode1 output clock period=7/2 lvds clk period<br>Set the output signal in debug mode. |
| 23    | R/W | 0x0 | LCD_LVDS_CORRECT_MODE<br>0: Mode0<br>1: Mode1<br>Set the lvds correct mode.                                                             |
| 22:21 | /   | /   | /                                                                                                                                       |
| 20    | R/W | 0x0 | LCD_LVDS_CLK_SEL<br>0: Reserved<br>1: LCD CLK<br>Select the clock source of lvds.                                                       |
| 19:5  | /   | /   | /                                                                                                                                       |
| 4     | R/W | 0x0 | LCD_LVDS_CLOCK_POL<br>0: Reverse<br>1: Normal<br>Set the clock polarity of lvds.                                                        |
| 3:0   | R/W | 0x0 | LCD_LVDS_DATA_POL<br>0: Reverse<br>1: Normal<br>Set the data polarity of lvds.                                                          |

#### 6.1.6.20. 0x0088 LCD IO Polarity Register(Default Value: 0x0000\_0000)

|                |                               |
|----------------|-------------------------------|
| Offset: 0x0088 | Register Name: LCD_IO_POL_REG |
|----------------|-------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                           |
|-------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | IO_OUTPUT_SEL<br>0: Normal output<br>1: Register output<br>When it is set as '1', d[23:0], io0, io1, io3 sync to dclk.                                                                                                                                |
| 30:28 | R/W        | 0x0         | DCLK_SEL<br>000: Used DCLK0(normal phase offset)<br>001: Used DCLK1(1/3 phase offset)<br>010: Used DCLK2(2/3 phase offset)<br>100: DCLK0/2 phase 0<br>101: DCLK0/2 phase 90<br>Others: Reserved<br>Set the phase offset of clock and data in hv mode. |
| 27    | R/W        | 0x0         | IO3_INV<br>0: Not invert<br>1: Invert<br>Enable invert function of IO3.                                                                                                                                                                               |
| 26    | R/W        | 0x0         | IO2_INV<br>0: Not invert<br>1: Invert<br>Enable invert function of IO2.                                                                                                                                                                               |
| 25    | R/W        | 0x0         | IO1_INV<br>0: Not invert<br>1: Invert<br>Enable invert function of IO1.                                                                                                                                                                               |
| 24    | R/W        | 0x0         | IO0_INV<br>0: Not invert<br>1: Invert<br>Enable invert function of IO0.                                                                                                                                                                               |
| 23:0  | R/W        | 0x0         | Data_INV<br>0: Normal polarity<br>1: Invert the specify output<br>LCD output port D[23:0] polarity control, with independent bit control.                                                                                                             |

#### 6.1.6.21. 0x008C LCD IO Control Register(Default Value: 0xFFFF\_FFFF)

| Offset: 0x008C |            |             | Register Name: LCD_IO_TRI_REG                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28             | R/W        | 0x0         | RGB_ENDIAN<br>0: Normal<br>1: Bits_invert<br>Set the endian of data bits. |
| 27             | R/W        | 0x1         | IO3_OUTPUT_TRI_EN                                                         |

|      |     |           |                                                                                                                       |
|------|-----|-----------|-----------------------------------------------------------------------------------------------------------------------|
|      |     |           | 1: Disable<br>0: Enable<br>Enable the output of IO3.                                                                  |
| 26   | R/W | 0x1       | IO2_OUTPUT_TRI_EN<br>1: Disable<br>0: Enable<br>Enable the output of IO2.                                             |
| 25   | R/W | 0x1       | IO1_OUTPUT_TRI_EN<br>1: Disable<br>0: Enable<br>Enable the output of IO1.                                             |
| 24   | R/W | 0x1       | IO0_OUTPUT_TRI_EN<br>1: Disable<br>0: Enable<br>Enable the output of IO0.                                             |
| 23:0 | R/W | 0xFFFFFFF | DATA_OUTPUT_TRI_EN<br>1: Disable<br>0: Enable<br>LCD output port D[23:0] output enable, with independent bit control. |

#### 6.1.6.22. 0x00FC LCD Debug Register(Default Value: 0x2000\_0000)

| Offset: 0x00FC |            |             | Register Name: LCD_DEBUG_REG                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31             | R          | 0x0         | LCD_FIFO_UNDERFLOW<br>0: Not underflow<br>1: Underflow<br>The flag shows whether the fifo is in underflow status. |
| 30             | /          | /           | /                                                                                                                 |
| 29             | R          | 0x1         | LCD_FIELD_POL<br>0: Second field<br>1: First field<br>The flag indicates the current field polarity.              |
| 28             | /          | /           | /                                                                                                                 |
| 27:16          | R          | 0x0         | LCD_CURRENT_LINE<br>The current scan line.                                                                        |
| 15:0           | /          | /           | /                                                                                                                 |

#### 6.1.6.23. 0x0100 LCD CEU Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: LCD_CEU_CTL_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |

|      |     |     |                                                          |
|------|-----|-----|----------------------------------------------------------|
| 31   | R/W | 0x0 | CEU_EN<br>0: Bypass<br>1: Enable<br>Enable CEU function. |
| 30   | R/W | 0x0 | BT656 F_MASK<br>0: Disable<br>1: Enable                  |
| 29   | R/W | 0x0 | BT656 F_MASK_VALUE<br>0/1                                |
| 28:0 | /   | /   | /                                                        |

#### 6.1.6.24. 0x0110+N\*0x04 LCD CEU Coefficient Register0(Default Value: 0x0000\_0000)

| Offset: 0x0110+N*0x04(N=0~10) |            | Register Name: LCD_CEU_COEF_MUL_REG |                                                                                                                                                                  |
|-------------------------------|------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex                         | Description                                                                                                                                                      |
| 31:13                         | /          | /                                   | /                                                                                                                                                                |
| 12:0                          | R/W        | 0x0                                 | CEU_COEF_MUL_VALUE<br>N=0: Rr<br>N=1: Rg<br>N=2: Rb<br>N=4: Gr<br>N=5: Gg<br>N=6: Gb<br>N=8: Br<br>N=9: Bg<br>N=10: Bb<br>Signed 13-bit value, range of (-16,16) |

#### 6.1.6.25. 0x011C+N\*0x10 LCD CEU Coefficient Add Register(Default Value: 0x0000\_0000)

| Offset: 0x011C+N*0x10(N=0~2) |            | Register Name: LCD_CEU_COEF_ADD_REG |                                                                                                      |
|------------------------------|------------|-------------------------------------|------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex                         | Description                                                                                          |
| 31:19                        | /          | /                                   | /                                                                                                    |
| 18:0                         | R/W        | 0x0                                 | CEU_COEF_ADD_VALUE<br>N=0: Rc<br>N=1: Gc<br>N=2: Bc<br>Signed 19-bit value, range of (-16384, 16384) |

#### 6.1.6.26. 0x0140+N\*0x04 LCD CEU Coefficient Range Register(Default Value: 0x0000\_0000)

| Offset: 0x0140+N*0x04(N=0~2) |            |             | Register Name: LCD_CEU_COEF_RANG_REG                         |
|------------------------------|------------|-------------|--------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                  |
| 31:24                        | /          | /           | /                                                            |
| 23:16                        | R/W        | 0x0         | CEU_COEF_RANGE_MIN<br>Unsigned 8-bit value, range of [0,255] |
| 15:8                         | /          | /           | /                                                            |
| 7:0                          | R/W        | 0x0         | CEU_COEF_RANGE_MAX<br>Unsigned 8-bit value, range of [0,255] |

#### 6.1.6.27. 0x0160 LCD CPU Panel Trigger Register0(Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: LCD_CPU_TRI0_REG                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:28          | /          | /           | /                                                                                     |
| 27:16          | R/W        | 0x0         | BLOCK_SPACE<br>The spaces between data blocks.<br>It should be set to 20*pixel above. |
| 15:12          | /          | /           | /                                                                                     |
| 11:0           | R/W        | 0x0         | BLOCK_SIZE<br>The size of data block. It is usually set as X.                         |

#### 6.1.6.28. 0x0164 LCD CPU Panel Trigger Register1(Default Value: 0x0000\_0000)

| Offset: 0x0164 |            |             | Register Name: LCD_CPU_TRI1_REG                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:16          | R          | 0x0         | BLOCK_CURRENT_NUM<br>Shows the current data block transmitting to panel. |
| 15:0           | R/W        | 0x0         | BLOCK_NUM<br>The number of data blocks. It is usually set as Y.          |

#### 6.1.6.29. 0x0168 LCD CPU Panel Trigger Register2(Default Value: 0x0000\_0000)

| Offset: 0x0168 |            |             | Register Name: LCD_CPU_TRI2_REG                         |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:16          | R/W        | 0x20        | START_DELAY<br>Tdly = (Start_Delay +1) * be_clk*8       |
| 15             | R/W        | 0x0         | TRANS_START_MODE<br>0: ecc_fifo+tri_fifo<br>1: tri_fifo |

|       |     |     |                                                                                           |
|-------|-----|-----|-------------------------------------------------------------------------------------------|
|       |     |     | Select the FIFOs used in CPU mode.                                                        |
| 14:13 | R/W | 0x0 | <p>SYNC_MODE<br/>0x: auto<br/>10: 0<br/>11: 1<br/>Set the sync mode in CPU interface.</p> |
| 12:0  | R/W | 0x0 | <p>TRANS_START_SET<br/>Usually set as the length of a line.</p>                           |

#### 6.1.6.30. 0x016C LCD CPU Panel Trigger Register3(Default Value: 0x0000\_0000)

| Offset: 0x016C |            |             | Register Name: LCD_CPU_TRI3_REG                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 29:28          | R/W        | 0x0         | <p>TRI_INT_MODE<br/>00: Disable<br/>01: Counter mode<br/>10: Te rising mode<br/>11: Te falling mode<br/>When it is set as 2b'01, Tri_Counter_Int occur in cycle of (Count_N+1)×(Count_M+1)×4 dclk.<br/>When it is set as 2b'10 or 2b'11, IO0 is map as TE input.</p> |
| 27:24          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 23:8           | R/W        | 0x0         | <p>COUNTER_N<br/>The value of counter factor.</p>                                                                                                                                                                                                                    |
| 7:0            | R/W        | 0x0         | <p>COUNTER_M<br/>The value of counter factor.</p>                                                                                                                                                                                                                    |

#### 6.1.6.31. 0x0170 LCD CPU Panel Trigger Register4(Default Value: 0x0000\_0000)

| Offset: 0x0170 |            |             | Register Name: LCD_CPU_TRI4_REG                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:29          | /          | /           | /                                                                                                   |
| 28             | R/W        | 0x0         | <p>PLUG_MODE_EN<br/>0: Disable<br/>1: Enable<br/>Enable the plug mode used in DSI command mode.</p> |
| 27:25          | /          | /           | /                                                                                                   |
| 24             | R/W        | 0x0         | A1<br>Valid in first Block.                                                                         |
| 23:0           | R/W        | 0x0         | D23-D0<br>Valid in first Block.                                                                     |

#### 6.1.6.32. 0x0174 LCD CPU Panel Trigger Register5(Default Value: 0x0000\_0000)

| Offset: 0x0174 |            |             | Register Name: LCD_CPU_TRI5_REG       |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:25          | /          | /           | /                                     |
| 24             | R/W        | 0x0         | A1<br>Valid in Block except first     |
| 23:0           | R/W        | 0x0         | D23-D0<br>Valid in Block except first |

#### 6.1.6.33. 0x0180 LCD Color Map Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0180 |            |             | Register Name: LCD_CMAP_CTL_REG                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 31             | R/W        | 0x0         | COLOR_MAP_EN<br>0: Bypass<br>1: Enable<br>Enable the color map function.<br>This module only work when X is divided by 4.                                        |
| 30:1           | /          | /           | /                                                                                                                                                                |
| 0              | R/W        | 0x0         | OUT_FORMAT<br>0: 4 pixel output mode: Out0 -> Out1 -> Out2 -> Out3<br>1: 2 pixel output mode: Out0 -> Out1<br>Set the pixel output format in color map function. |

#### 6.1.6.34. 0x0190 LCD Color Map Odd Line Register0(Default Value: 0x0000\_0000)

| Offset: 0x0190 |            |             | Register Name: LCD_CMAP_ODD0_REG                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                    |
| 31:16          | R/W        | 0x0         | OUT_ODD1<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1 |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0111:Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components.                                                                                                                                                                                                                                   |
| 15:0 | R/W | 0x0 | OUT_ODD0<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111:Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components. |

#### 6.1.6.35. 0x0194 LCD Color Map Odd Line Register1(Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: LCD_CMAP_ODD1_REG                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31:16          | R/W        | 0x0         | OUT_ODD3<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0 |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components.                                                                                                                                                     |
| 15:0 | R/W | 0x0 | OUT_ODD2<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components. |

#### 6.1.6.36. 0x0198 LCD Color Map Even Line Register0(Default Value: 0x0000\_0000)

| Offset: 0x0198 |            |             | Register Name: LCD_CMAP_EVEN0_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:16          | R/W        | 0x0         | OUT_EVEN1<br>bit15-12: Reserved   |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components.                                    |
| 15:0 | R/W | 0x0 | OUT_EVEN0<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved<br>Indicates the output order of components. |

**6.1.6.37. 0x019C LCD Color Map Even Line Register1(Default Value: 0x0000\_0000)**

| Offset: 0x019C |            |             | Register Name: LCD_CMAP_EVEN1_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:16          | R/W        | 0x0         | <p>OUT_EVEN3</p> <p>bit15-12: Reserved</p> <p>bit11-08: Out_Odd0[23:16]</p> <p>bit07-04: Out_Odd0[15:8]</p> <p>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0</p> <p>0001: in_g0</p> <p>0010: in_r0</p> <p>0011: Reserved</p> <p>0100: in_b1</p> <p>0101: in_g1</p> <p>0110: in_r1</p> <p>0111: Reserved</p> <p>1000: in_b2</p> <p>1001: in_g2</p> <p>1010: in_r2</p> <p>1011: Reserved</p> <p>1100: in_b3</p> <p>1101: in_g3</p> <p>1110: in_r3</p> <p>1111: Reserved</p> <p>Indicates the output order of components.</p> |
| 15:0           | R/W        | 0x0         | <p>OUT_EVEN2</p> <p>bit15-12: Reserved</p> <p>bit11-08: Out_Odd0[23:16]</p> <p>bit07-04: Out_Odd0[15:8]</p> <p>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0</p> <p>0001: in_g0</p> <p>0010: in_r0</p> <p>0011: Reserved</p> <p>0100: in_b1</p> <p>0101: in_g1</p> <p>0110: in_r1</p> <p>0111: Reserved</p> <p>1000: in_b2</p> <p>1001: in_g2</p> <p>1010: in_r2</p> <p>1011: Reserved</p> <p>1100: in_b3</p> <p>1101: in_g3</p>                                                                                           |

|  |  |  |                                                                                     |
|--|--|--|-------------------------------------------------------------------------------------|
|  |  |  | <p>1110: in_r3<br/>1111: Reserved<br/>Indicates the output order of components.</p> |
|--|--|--|-------------------------------------------------------------------------------------|

#### 6.1.6.38. 0x01F0 LCD Safe Period Register(Default Value: 0x0000\_0000)

| Offset: 0x01F0 |            |             | Register Name: LCD_SAFE_PERIOD_REG                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:29          | /          | /           | /                                                                                                                                                                                                         |
| 28:16          | R/W        | 0x0         | <p>SAFE_PERIOD_FIFO_NUM<br/>When the data length in line buffer is more than SAFE_PERIOD_FIFO_NUM, LCD controller will allow dram controller to stop working to change frequency.</p>                     |
| 15:4           | R/W        | 0x0         | <p>SAFE_PERIOD_LINE<br/>Set a fixed line and during the line time, LCD controller allow dram controller to change frequency. The fixed line should be set in the blanking area.</p>                       |
| 3              | /          | /           | /                                                                                                                                                                                                         |
| 2:0            | R/W        | 0x0         | <p>SAFE_PERIOD_MODE<br/>000: unsafe<br/>001: safe<br/>010: safe at FIFO_CURR_NUM &gt; SAFE_PERIOD_FIFO_NUM<br/>011: safe at 2 and safe at sync active<br/>100: safe at line<br/>Select the safe mode.</p> |

#### 6.1.6.39. 0x0220 LCD LVDS Analog Register 0(Default Value: 0x0000\_0000)

| Offset: 0x220 |            |             | Register Name: LCD_LVDS0_ANA_REG                                                                   |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                        |
| 31            | R/W        | 0x0         | <p>LVDS_EN_MB<br/>Enable the bias circuit of the LVDS_ANA module.<br/>0: Disable<br/>1: Enable</p> |
| 30            | R/W        | 0x0         | Reserved                                                                                           |
| 29            | R/W        | 0x0         | <p>EN_LVDS<br/>Enable LVDS.</p>                                                                    |
| 28            | R/W        | 0x0         | <p>EN_24M<br/>Enable the 24M clock.</p>                                                            |
| 27:25         | /          | /           | /                                                                                                  |
| 24            | R/W        | 0x0         | <p>LVDS_HPREN_DRVC<br/>Enable clock channel drive<br/>0: disable</p>                               |

|       |     |     |                                                                                                                                                                                                                                         |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: enable                                                                                                                                                                                                                               |
| 23:20 | R/W | 0x0 | <b>LVDS_HPREN_DRV</b><br>Enable clock channel[3:0] drive<br>0: disable<br>1: enable                                                                                                                                                     |
| 19:17 | R/W | 0x0 | <b>LVDS_REG_C</b><br>Adjust current flowing through rload of rx to change the differential signals amplitude<br>000: 216 mV<br>001: 252 mV<br>010: 276 mV<br>011: 312 mV<br>100: 336 mV<br>101: 372 mV<br>110: 395 mV<br>111: 432 mV    |
| 16    | R/W | 0x0 | <b>LVDS_REG_DENC</b><br>Choose data output or pll test clock output in LVDS_TX                                                                                                                                                          |
| 15:12 | R/W | 0x0 | <b>LVDS_REG_DEN</b><br>Choose data output or pll test clock output in LVDS_TX                                                                                                                                                           |
| 11    | /   | /   | /                                                                                                                                                                                                                                       |
| 10:8  | R/W | 0x0 | <b>LVDS_REG_R</b><br>Adjust current flowing through rload of rx to change the common signals amplitude.<br>000: 0.925 V<br>001: 0.950 V<br>010: 0.975 V<br>011: 1.000 V<br>100: 1.025 V<br>101: 1.050 V<br>110: 1.075 V<br>111: 1.100 V |
| 7:5   | /   | /   | /                                                                                                                                                                                                                                       |
| 4     | R/W | 0x0 | <b>LVDS_REG_PLRC</b><br>Lvds clock channel direction<br>0: Normal<br>1: Reverse                                                                                                                                                         |
| 3:0   | R/W | 0x0 | <b>LVDS_REG_PLR</b><br>Lvds data channel[3:0] direction<br>0: Normal<br>1: Reverse                                                                                                                                                      |

#### 6.1.6.40. 0x0230 LCD Sync Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: LCD_SYNC_CTL_REG                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                       |
| 8              | R/W        | 0x0         | LCD_CONTROLLER_WORK_MODE<br>0:Single DSI mode<br>1:Dual DSI mode                                                        |
| 7:5            | /          | /           | /                                                                                                                       |
| 4              | R/W        | 0x0         | LCD_CONTROLLER_SYNC_MASTER_SLAVE<br>0:Master<br>1:Slave<br><b>Note: Only use in Single DSI mode.</b>                    |
| 3:1            | /          | /           | /                                                                                                                       |
| 0              | R/W        | 0x0         | LCD_CONTROLLER_SYNC_MODE<br>0:Sync in the first time<br>1:Sync every frame<br><b>Note: Only use in Single DSI mode.</b> |

#### 6.1.6.41. 0x0234 LCD Sync Position Register(Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: LCD_SYNC_POS_REG                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                              |
| 31:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                        |
| 27:16          | R/W        | 0x0         | LCD_SYNC_PIXEL_NUM<br>Set the pixel number of master LCD controller which is used to trigger the slave LCD controller to start working. This value is the number of pixels between the trigger point and the end of the line.<br>Tri pos = Tline*LCD_Sync_Line_Num+Tpixel*(HT-LCD_Sync_Pixel_Num)<br><b>Note: Only use in Single DSI mode.</b>           |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                        |
| 11:0           | R/W        | 0x0         | LCD_SYNC_LINE_NUM<br>Set the line number of master LCD controller which is used to trigger the slave LCD controller to start working.<br>It is only set in master LCD controller. It is not necessarily to set in slave LCD controller.<br>Tri pos = Tline*LCD_Sync_Line_Num+Tpixel*(HT-LCD_Sync_Pixel_Num)<br><b>Note: Only use in Single DSI mode.</b> |

#### 6.1.6.42. 0x0238 LCD Slave Stop Position Register(Default Value: 0x0000\_0000)

|                |                                      |
|----------------|--------------------------------------|
| Offset: 0x0238 | Register Name:LCD_SLAVE_STOP_POS_REG |
|----------------|--------------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                             |
|------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | /          | /           | /                                                                                                                                                                                                                                       |
| 7:0  | R/W        | 0x0         | STOP_VAL<br>Set the stop position of the slave LCD. This value is the number of pixels between the stop position and the end of the HFP.<br>Stop_pos = HFP - Stop_val.<br>0<Stop_pos<HFP-2.<br><b>Note:Only use in Single DSI mode.</b> |

#### 6.1.6.43. 0x0400~0x07FF LCD Gamma Table Register(Default Value: 0x0000\_0000)

| Offset: 0x0400~0x07FF |            |             | Register Name: LCD_GAMMA_TABLE_REG |
|-----------------------|------------|-------------|------------------------------------|
| Bit                   | Read/Write | Default/Hex | Description                        |
| 31:24                 | /          | /           | /                                  |
| 23:16                 | R/W        | 0x00        | Red Component                      |
| 15:8                  | R/W        | 0x00        | Green Component                    |
| 7:0                   | R/W        | 0x00        | Blue Component                     |

## 6.2. DSI

### 6.2.1. Overview

The Display Serial Interface (DSI) is a high-speed interface between a host processor and peripheral devices that adhere to MIPI Alliance specifications for mobile device interfaces. This DSI module is composed of a DSI controller which is compliance with MIPI DSI specification V1.01 and a D-PHY module which is compliance with MIPI DPHY specification V1.00.

#### DSI Host Features:

- Compliance with MIPI DSI v1.01
- Supports up to 4 lanes
- Maximum 1920 x 1200@60fps performance for MIPI DSI
- Supports non-burst mode with sync pulse/sync event, burst mode and command mode
- Supports pixel format: RGB888, RGB666, RGB666 loosely packed and RGB565
- Supports continuous lane clock mode and non-continuous lane clock mode
- Compliance with MIPI DCS v1.01, bidirectional communication in LP through data lane 0
- Supports bidirectional communication of all generic commands in LP through data lane 0
- Supports low power data transmission
- Supports ULPS and escape modes
- Hardware checksum capabilities

#### D-PHY Features:

- Compliance with D-PHY v1.00
- Supports up to 4 lanes, and lane speed up to 2 Gbps per lane in forward direction
- Aggregate throughput up to 8 Gbps with 4 data lanes
- Bidirectional communication in low power mode through data lane 0
- Supports low power Escape mode and Ultra Low Power state
- Supports multiplex with GPIO, GPIO can work in 3.3 V or 1.8 V power supply

### 6.2.2. Block Diagram



Figure 6- 14. MIPI DSI System Block Diagram

TCON is connected with DSI Controller through DPI and DBI. Packet Maker transforms pixel data of TCON into data packets based on a designated mode(video mode with sync pulse/video mode with sync event/burst mode/command mode). PHY Control distributes data packets to every lane, and starts filling for alignment. After data packets arrive at DPHY, the data packets start to serialize, then they are sent into sink end. The ERR processor monitors the whole process, if there is a mistake, the corresponding state position is set to "1".



Figure 6- 15. MIPI DSI Internal Unit

TCON synchronous signals come into DSI Controller, and input into Time Ctrl. According to TCON synchronous signals,

the Time Ctrl controls and drives the operation of every sub module.



**Figure 6- 16. DPHY Block Diagram**

Serialization and deserialization of high speed data are operated in the analog part of DPHY. The digital and analog part of DPHY use two different clocks, so the transmit process and receive process of high speed data are asynchronous. The work clock of digital part is Byte Clock, usually set at about 150 MHz, which are lower than clocks of analog part. In order to provide the reliability of transmission, the DPHY supports 9-bit encoding mode, but it needs extra bandwidth to transmit additional bits.

### 6.2.3. Operations and Functional Descriptions

#### 6.2.3.1. External Signals

The following table describes the external signals of MIPI DSI.

**Table 6- 9. MIPI DSI External Signals**

| Signal  | Description                | Type |
|---------|----------------------------|------|
| DSI_DPO | The positive port of lane0 | AI/O |

|         |                                 |      |
|---------|---------------------------------|------|
| DSI_DM0 | The negative port of lane0      | AI/O |
| DSI_DP1 | The positive port of lane1      | AO   |
| DSI_DM1 | The negative port of lane1      | AO   |
| DSI_DP2 | The positive port of lane2      | AO   |
| DSI_DM2 | The negative port of lane2      | AO   |
| DSI_DP3 | The positive port of lane3      | AO   |
| DSI_DM3 | The negative port of lane3      | AO   |
| DSI_CKP | The positive port of clock lane | AO   |
| DSI_CKM | The negative port of clock lane | AO   |

### 6.2.3.2. Clock Sources

The following tables describe the clock sources of MIPI DSI. Table 6-10 describes the clock sources of MIPI DSI Controller and Table 6-11 describes the clock source of D-PHY.

Table 6- 10. MIPI DSI Controller Clock Sources

| Clock Sources | Description                                                  |
|---------------|--------------------------------------------------------------|
| Local Clock   | The clock for DSI Host configuration,which is about 150 MHz. |

Table 6- 11. MIPI D-PHY Clock Source

| Clock Sources | Description          |
|---------------|----------------------|
| D-PHY Clock   | The clock for D-PHY. |



Figure 6- 17. MIPI DSI Clock System

The DPHY CLK is the lane bit clock in high speed mode, which obtained by OSC24M frequency doubling and frequency division. The DPHY CLK is controlled by DPHY\_PLL\_REF0(reg0x1104), HS\_phy\_clk=24MHz\*n/(p+1)/(m0+1), p is not 0; after the frequency configuration completes, start cp36\_en, ldo\_en, en\_lvs, pll\_en, and enable COMBOPHY PLL.

```
dphy_dev_40[sel]->dphy_pll_reg0.bits.n = n; //HS_clk:24MHz*n/(p+1)/(m0+1);
dphy_dev_40[sel]->dphy_pll_reg0.bits.p = div_p;
dphy_dev_40[sel]->dphy_pll_reg0.bits.m0 = div_m0;
dphy_dev_40[sel]->dphy_pll_reg0.bits.m1 = div_m1;
```

#### 6.2.3.3. MIPI DSI Protocol Escape Entry

The following table shows the escape entry codes in MIPI DSI.

**Table 6- 12. Escape Entry Codes**

| Escape Mode Action                 | Command Type | Entry Command Pattern (first bit transmitted to last bit transmitted) |
|------------------------------------|--------------|-----------------------------------------------------------------------|
| Low-Power Data Transmission        | Mode         | 11100001                                                              |
| Ultra-Low Power State              | Mode         | 00011110                                                              |
| Undefined-1                        | Mode         | 10011111                                                              |
| Undefined-2                        | Mode         | 11011110                                                              |
| Reset-Trigger [Remote Application] | Trigger      | 01100010                                                              |
| Unknown-3                          | Trigger      | 01011101                                                              |
| Unknown-4                          | Trigger      | 00100001                                                              |
| Unknown-5                          | Trigger      | 10100000                                                              |

#### 6.2.3.4. MIPI DSI Date Type

The set of transaction types sent from the host processor to a peripheral, such as a display module, are shown below.

**Table 6- 13. Data Types for Processor-sourced Packets**

| Data Type(hex) | Data Type(binary) | Description                       | Packet Size |
|----------------|-------------------|-----------------------------------|-------------|
| 01h            | 00 0001           | Sync Event, V Sync Start          | Short       |
| 11h            | 01 0001           | Sync Event, V Sync End            | Short       |
| 21h            | 10 0001           | Sync Event, H Sync Start          | Short       |
| 31h            | 11 0001           | Sync Event, H Sync End            | Short       |
| 08h            | 00 1000           | End of Transmission packet (EoTp) | Short       |
| 02h            | 00 0010           | Color Mode (CM) Off Command       | Short       |
| 12h            | 01 0010           | Color Mode (CM) On Command        | Short       |
| 22h            | 10 0010           | Shut Down Peripheral Command      | Short       |
| 32h            | 11 0010           | Turn On Peripheral Command        | Short       |

|                             |                 |                                                       |       |
|-----------------------------|-----------------|-------------------------------------------------------|-------|
| 03h                         | 00 0011         | Generic Short WRITE, no parameters                    | Short |
| 13h                         | 01 0011         | Generic Short WRITE, 1 parameter                      | Short |
| 23h                         | 10 0011         | Generic Short WRITE, 2 parameters                     | Short |
| 04h                         | 00 0100         | Generic READ, no parameters                           | Short |
| 14h                         | 01 0100         | Generic READ, 1 parameter                             | Short |
| 24h                         | 10 0100         | Generic READ, 2 parameters                            | Short |
| 05h                         | 00 0101         | DCS Short WRITE, no parameters                        | Short |
| 15h                         | 01 0101         | DCS Short WRITE, 1 parameter                          | Short |
| 06h                         | 00 0110         | DCS READ, no parameters                               | Short |
| 37h                         | 11 0111         | Set Maximum Return Packet Size                        | Short |
| 09h                         | 00 1001         | Null Packet, no data                                  | Long  |
| 19h                         | 01 1001         | Blanking Packet, no data                              | Long  |
| 29h                         | 10 1001         | Generic Long Write                                    | Long  |
| 39h                         | 11 1001         | DCS Long Write/write_LUT Command Packet               | Long  |
| 0Eh                         | 00 1110         | Packed Pixel Stream, 16-bit RGB, 5-6-5 Format         | Long  |
| 1Eh                         | 01 1110         | Packed Pixel Stream, 18-bit RGB, 6-6-6 Format         | Long  |
| 2Eh                         | 10 1110         | Loosely Packed Pixel Stream, 18-bit RGB, 6-6-6 Format | Long  |
| 3Eh                         | 11 1110         | Packed Pixel Stream, 24-bit RGB, 8-8-8 Format         | Long  |
| x0h and xFh,<br>unspecified | xx 0000 xx 1111 | DO NOT USE, all unspecified codes are reserved        |       |

The following table presents the complete set of peripheral-to-processor Data Types.

Table 6- 14. Complete Set of Peripheral-to-Processor Data Types

| Data Type(hex) | Data Type(binary) | Description                                   | Packet Size |
|----------------|-------------------|-----------------------------------------------|-------------|
| 00h – 01h      | 00 000x           | Reserved                                      | Short       |
| 02h            | 00 0010           | Acknowledge and Error Report                  | Short       |
| 03h – 07h      | 00 0011 – 00 0111 | Reserved                                      |             |
| 08h            | 00 1000           | End of Transmission packet (EoTp)             | Short       |
| 09h – 10h      | 00 1001 – 01 0000 | Reserved                                      |             |
| 11h            | 01 0001           | Generic Short READ Response, 1 byte returned  | Short       |
| 12h            | 01 0010           | Generic Short READ Response, 2 bytes returned | Short       |
| 13h – 19h      | 01 0011 – 01 1001 | Reserved                                      |             |
| 1Ah            | 01 1010           | Generic Long READ Response                    | Long        |
| 1Bh            | 01 1011           | Reserved                                      |             |
| 1Ch            | 01 1100           | DCS Long READ Response                        | Long        |
| 1Dh – 20h      | 01 1101 – 10 0000 | Reserved                                      |             |
| 21h            | 10 0001           | DCS Short READ Response, 1 byte returned      | Short       |

| Data Type(hex) | Data Type(binary) | Description                               | Packet Size |
|----------------|-------------------|-------------------------------------------|-------------|
| 22h            | 10 0010           | DCS Short READ Response, 2 bytes returned | Short       |
| 23h – 3Fh      | 10 0011 – 11 1111 | Reserved                                  |             |

The following table shows the bit assignment for all error reporting.

**Table 6- 15. Error Report Bit Definitions**

| Bit | Description                                    |
|-----|------------------------------------------------|
| 0   | SoT Error                                      |
| 1   | SoT Sync Error                                 |
| 2   | EoT Sync Error                                 |
| 3   | Escape Mode Entry Command Error                |
| 4   | Low-Power Transmit Sync Error                  |
| 5   | HS Receive Timeout Error                       |
| 6   | False Control Error                            |
| 7   | Reserved                                       |
| 8   | ECC Error, single-bit (detected and corrected) |
| 9   | ECC Error, multi-bit (detected, not corrected) |
| 10  | Checksum Error (Long packet only)              |
| 11  | DSI Data Type Not Recognized                   |
| 12  | DSI VC ID Invalid                              |
| 13  | Invalid Transmission Length                    |
| Bit | Description                                    |
| 14  | Reserved                                       |
| 15  | DSI Protocol Violation                         |

#### 6.2.3.5. D-PHY Lane State

The following table shows all the lane states of D-PHY in MIPI DSI standard.

**Table 6- 16. D-PHY Lane State**

| State Code | Line Voltage Levels |         | High-Speed     | Low-Power    |             |
|------------|---------------------|---------|----------------|--------------|-------------|
|            | Dp-Line             | Dn-Line | Burst Mode     | Control Mode | Escape Mode |
| HS-0       | HS Low              | HS High | Differential-0 | N/A          | N/A         |
| HS-1       | HS High             | HS Low  | Differential-1 | N/A          | N/A         |
| LP-00      | LP Low              | LP Low  | N/A            | Bridge       | Space       |
| LP-01      | LP Low              | LP High | N/A            | HS-Rqst      | Mark-0      |
| LP-10      | LP High             | LP Low  | N/A            | LP-Rqst      | Mark-1      |
| LP-11      | LP High             | LP High | N/A            | Stop         | N/A         |

### 6.2.3.6. D-PHY Lane Sequence

#### The sequence in data lane:

SOT sequence: LP-11,LP-01,LP-00,HS Sync-sequence ('00011101')

EOT sequence: Diff HS-0 or HS-1, LP-11

Escape mode request: LP-11, LP-10, LP-00,LP-01,LP-00, Escape Entry Command

The following table shows the supported entry command.

**Table 6- 17. Entry Command**

| Escape Mode Action                    | Command Type | Entry Command Pattern |
|---------------------------------------|--------------|-----------------------|
| Ultra-Low Power State                 | mode         | 00011110              |
| Reset-Trigger<br>[Remote Application] | Trigger      | 01100010              |

#### The sequence in clock lane:

Clock Lane only supports ULPS, an Escape mode entry code is not required.

During Data and Clock ULPS state, the lines are in the Space state (LP-00). Ultra-Low Power State is exited by means of a Mark-1 state with a length TWAKEUP followed by a Stop state.

### 6.2.3.7. D-PHY Timing

#### SOT and EOT:



**Figure 6- 18. DPHY SOT and EOT Timing**

#### Escape mode timing:



Figure 6- 19. DPHY Escape Mode Timing

Ultra-Low Power State is exited by means of a Mark-1 state with a length  $T_{WAKEUP}$  followed by a Stop state.

#### Clock switching between HS and LP:



Figure 6- 20. Switching Between HS and LP Timing

#### 6.2.3.8. D-PHY Error Behavior

##### (1) SoT Error

The Leader sequence for Start of High-Speed Transmission is fault tolerant for any single-bit error. The synchronization

may be usable, but confidence in the payload data is lower. If this situation occurs, an SoT Error is indicated.

## (2) SoT Sync Error

If the SoT Leader sequence is corrupted in a way that proper synchronization cannot be expected, a SoT Sync Error is indicated.

## (3) Escape Mode Entry Command Error

If the receiving Lane Module does not recognize the received Entry Command for Escape mode, an Escape mode Entry Command Error is indicated.

## (4) False Control Error

If a LP-Rqst (LP-10) is not followed by the remainder of a valid Escape sequence, a False Control Error is indicated. This error is also indicated if a HS-Rqst (LP-01) is not correctly followed by a Bridge State (LP-00).

## 6.2.4. Programming Guidelines

### 6.2.4.1. Video Mode Initial Sequence

The following diagram shows the initial sequence for video mode.



Figure 6- 21. Video Mode Initial Sequence

### 6.2.4.2. Command Mode Initial Sequence

The following diagram shows the initial sequence for command mode.



Figure 6- 22. Command Mode Initial Sequence

### 6.2.5. Register List

| Module Name           | Base Address |
|-----------------------|--------------|
| COMBO_PHY_TX_DSI      | 0x06504000   |
| COMBO_PHY_TX_GPIO_DSI | 0x06504400   |

| Register Name        | Offset        | Description                                            |
|----------------------|---------------|--------------------------------------------------------|
| DSI_CTL_REG          | 0x0000        | DSI Control Register                                   |
| DSI_GINT0_REG        | 0x0004        | DSI Global Interrupt Register0                         |
| DSI_GINT1_REG        | 0x0008        | DSI Global Interrupt Register1                         |
| DSI_BASIC_CTL_REG    | 0x000C        | DSI Basic Control Register                             |
| DSI_BASIC_CTL0_REG   | 0x0010        | DSI Basic Control Register0                            |
| DSI_BASIC_CTL1_REG   | 0x0014        | DSI Basic Control Register1                            |
| DSI_BASIC_SIZE0_REG  | 0x0018        | DSI Basic Timing Register0                             |
| DSI_BASIC_SIZE1_REG  | 0x001C        | DSI Basic Timing Register1                             |
| DSI_BASIC_INST0_REG  | 0x0020+N*0x04 | DSI Basic Instruction Register0<br>(N=0,1,2,3,4,5,6,7) |
| DSI_BASIC_INST1_REG  | 0x0040        | DSI Basic Instruction Register1                        |
| DSI_BASIC_INST2_REG  | 0x0044        | DSI Basic Instruction Register2                        |
| DSI_BASIC_INST3_REG  | 0x0048        | DSI Basic Instruction Register3                        |
| DSI_BASIC_INST4_REG  | 0x004C        | DSI Basic Instruction Register4                        |
| DSI_BASIC_INST5_REG  | 0x0050        | DSI Basic Instruction Register5                        |
| DSI_BASIC_INST6_REG  | 0x0054        | DSI Basic Instruction Register6                        |
| DSI_BASIC_TRAN0_REG  | 0x0060        | DSI Basic Transmission Register0                       |
| DSI_BASIC_TRAN4_REG  | 0x0078        | DSI Basic Transmission Register4                       |
| DSI_BASIC_TRANS5_REG | 0x007C        | DSI Basic Transmission Register5                       |
| DSI_PIXEL_CTL0_REG   | 0x0080        | DSI Pixel Control Register0                            |

|                      |                                      |                                                |
|----------------------|--------------------------------------|------------------------------------------------|
| DSI_PIXEL_PH_REG     | 0x0090                               | DSI Pixel Packet Header Register               |
| DSI_PIXEL_PD_REG     | 0x0094                               | DSI Pixel Packet Data Register                 |
| DSI_PIXEL_PFO_REG    | 0x0098                               | DSI Pixel Packet Footer Register0              |
| DSI_PIXEL_PF1_REG    | 0x009C                               | DSI Pixel Packet Footer Register1              |
| DSI_SYNC_HSS_REG     | 0x00B0                               | DSI H Sync Start Register                      |
| DSI_SYNC_HSE_REG     | 0x00B4                               | DSI H Sync End Register                        |
| DSI_SYNC_VSS_REG     | 0x00B8                               | DSI V Sync Start Register                      |
| DSI_SYNC_VSE_REG     | 0x00BC                               | DSI V Sync End Register                        |
| DSI_BLK_HSA0_REG     | 0x00C0                               | DSI Blanking H Sync Active Register0           |
| DSI_BLK_HSA1_REG     | 0x00C4                               | DSI Blanking H Sync Active Register1           |
| DSI_BLK_HBPO_REG     | 0x00C8                               | DSI Blanking H Back Porch Register0            |
| DSI_BLK_HBP1_REG     | 0x00CC                               | DSI Blanking H Back Porch Register0            |
| DSI_BLK_HFPO_REG     | 0x00D0                               | DSI Blanking H Front Porch Register0           |
| DSI_BLK_HFP1_REG     | 0x00D4                               | DSI Blanking H Front Porch Register1           |
| DSI_BLK_HBLK0_REG    | 0x00E0                               | DSI H Blanking Register0                       |
| DSI_BLK_HBLK1_REG    | 0x00E4                               | DSI H Blanking Register1                       |
| DSI_BLK_VBLK0_REG    | 0x00E8                               | DSI V Blanking Register0                       |
| DSI_BLK_VBLK1_REG    | 0x00EC                               | DSI V Blanking Register1                       |
| DSI_BURST_LINE_REG   | 0x00F0                               | DSI Burst Line Register                        |
| DSI_BURST_DRQ_REG    | 0x00F4                               | DSI Burst DRQ Register                         |
| DSI_DEBUG_REG        | 0x00FC                               | DSI Debug Register                             |
| DSI_BASIC_INST10_REG | 0x0120+N*0x04(N=0,1,2,3,4,5,6)       | DSI Basic INST10 Register                      |
| DSI_BASIC_INST11_REG | 0x0140                               | DSI Basic INST11 Register                      |
| DSI_BASIC_INST13_REG | 0x0148                               | DSI Basic INST13 Register                      |
| DSI_SAFE_PERIOD_REG  | 0x01F0                               | DSI Safe Period Register                       |
| DSI_CMD_CTL_REG      | 0x0200                               | DSI Command Control Register                   |
| DSI_CMD_RX_REG       | 0x0240+N*0x04<br>(N=0,1,2,3,4,5,6,7) | DSI Command RX Register<br>(N=0,1,2,3,4,5,6,7) |
| DSI_CMD_TX_REG       | 0x0300+N*0x04<br>(N=0,1,2,...,63)    | DSI Command TX Register<br>(N=0,1,2,...,63)    |
| DSI_DEBUG0_REG       | 0x02E0                               | DSI Debug Register0                            |
| DSI_DEBUG1_REG       | 0x02E4                               | DSI Debug Register1                            |
| DSI_INST_DEBUG_REG   | 0x02EC                               | DSI INST Debug Register                        |
| DSI_DEBUG2_REG       | 0x02F0                               | DSI Debug Register2                            |
| DSI_DEBUG3_REG       | 0x02F4                               | DSI Debug Register3                            |
| DSI_DEBUG4_REG       | 0x02F8                               | DSI Debug Register4                            |
| DSI_FIFO_BIST_REG    | 0x0FF8                               | DSI FIFO Bist Register                         |

The following addresses need add offset 0x4000.

|                   |        |                                     |
|-------------------|--------|-------------------------------------|
| DPHY_CTL_REG      | 0x1000 | DPHY Control Register               |
| DPHY_TX_CTL_REG   | 0x1004 | DPHY TX Control Register            |
| DPHY_TX_TIME0_REG | 0x1010 | DPHY TX Timing Parameter 0 Register |
| DPHY_TX_TIME1_REG | 0x1014 | DPHY TX Timing Parameter 1 Register |
| DPHY_TX_TIME2_REG | 0x1018 | DPHY TX Timing Parameter 2 Register |
| DPHY_TX_TIME3_REG | 0x101C | DPHY TX Timing Parameter 3 Register |

|                   |        |                                     |
|-------------------|--------|-------------------------------------|
| DPHY_TX_TIME4_REG | 0x1020 | DPHY TX Timing Parameter 4 Register |
| DPHY_RX_TIME0_REG | 0x1030 | DPHY RX Timing Parameter 0 Register |
| DPHY_RX_TIME1_REG | 0x1034 | DPHY RX Timing Parameter 1 Register |
| DPHY_RX_TIME3_REG | 0x1040 | DPHY RX Timing Parameter 3 Register |
| DPHY_ANA0_REG     | 0x104C | DPHY Analog 0 Register              |
| DPHY_ANA1_REG     | 0x1050 | DPHY Analog 1 Register              |
| DPHY_ANA2_REG     | 0x1054 | DPHY Analog 2 Register              |
| DPHY_ANA3_REG     | 0x1058 | DPHY Analog 3 Register              |
| DPHY_ANA4_REG     | 0x105C | DPHY Analog 4 Register              |
| DPHY_INT_EN0_REG  | 0x1060 | DPHY Interrupt Enable 0 Register    |
| DPHY_INT_EN1_REG  | 0x1064 | DPHY Interrupt Enable 1 Register    |
| DPHY_INT_EN2_REG  | 0x1068 | DPHY Interrupt Enable 2 Register    |
| DPHY_INT_PDO_REG  | 0x1070 | DPHY Interrupt Pending 0 Register   |
| DPHY_INT_PD1_REG  | 0x1074 | DPHY Interrupt Pending 1 Register   |
| DPHY_DBG0_REG     | 0x10E0 | DPHY Debug 0 Register               |
| DPHY_DBG1_REG     | 0x10E4 | DPHY Debug 1 Register               |
| DPHY_DBG2_REG     | 0x10E8 | DPHY Debug 2 Register               |
| DPHY_DBG3_REG     | 0x10EC | DPHY Debug 3 Register               |
| DPHY_DBG4_REG     | 0x10F0 | DPHY Debug 4 Register               |
| DPHY_TX_SKEW_REG0 | 0x10F8 | DPHY TX Skew Register0              |
| DPHY_TX_SKEW_REG1 | 0x10FC | DPHY TX Skew Register1              |
| DPHY_TX_SKEW_REG2 | 0x1100 | DPHY TX Skew Register2              |
| DPHY_PLL_REG0     | 0x1104 | DPHY PLL Register0                  |
| DPHY_PLL_REG1     | 0x1108 | DPHY PLL Register1                  |
| COMBO_PHY_REG0    | 0x1110 | Combo PHY Register0                 |
| COMBO_PHY_REG1    | 0x1114 | Combo PHY Register1                 |

## 6.2.6. Registers Description

### 6.2.6.1. 0x0000 DSI Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: DSI_CTL_REG                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:1           | /          | /           | /                                                                                                 |
| 0              | R/W        | 0x0         | DSI_EN<br>0: Disable<br>1: Enable<br>When it is disabled, the module will be reset to idle state. |

### 6.2.6.2. 0x0004 DSI Global Interrupt Register0(Default Value: 0x0000\_0000)

| Offset: 0x0004 | Register Name: DSI_GINT0_REG |
|----------------|------------------------------|
|----------------|------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                      |
| 27    | R          | 0x0         | PDE_PEDGE_IN_DRQ_ERR<br>In video mode:<br>Drq is the signal that dsi request data from tcon.<br>Pde is the data valid signal that tcon send data to dsi.<br>If during an active time of Drq signal, there is no rising edge of Pde or there are more than 1 rising edge of Pde appeared, it indicates that an error occurs, this bit will be set to 1. |
| 26    | R          | 0x0         | PDE_PEDGE_IN_DRQ_TOO_MANY<br>If during an active time of Drq signal, there is more than 1 rising edge appeared, it indicates that an timing error occurs, this bit will be set to 1.                                                                                                                                                                   |
| 25    | R          | 0x0         | PDE_NEDGE_IN_DRQ_ERR<br>Drq is the signal that dsi request data from tcon.<br>Pde is the data valid signal that tcon send data to dsi.<br>If during an active time of Drq signal, there is no falling edge of Pde or there are more than 1 rising edge of Pde appeared, it indicates that an error occurs, this bit will be set to 1.                  |
| 24    | R          | 0x0         | PDE_NEDGE_IN_DRQ_TOO_MANY<br>If during an active time of Drq signal, there are more than 1 falling edge appeared, it indicates that an timing error occurs, this bit will be set to 1.                                                                                                                                                                 |
| 23:21 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                      |
| 20    | R          | 0x0         | BURST_LP_OVERLAP<br>When enabled HS transmission, if the LP driver source is still working, an error occurs, this bit will be set to 1.                                                                                                                                                                                                                |
| 19    | R          | 0x0         | LINE_INT_FLAG<br>The flag of line interrupt.                                                                                                                                                                                                                                                                                                           |
| 18    | R          | 0x0         | VB_INT_FLAG<br>The flag of Vb interrupt.                                                                                                                                                                                                                                                                                                               |
| 17    | R          | 0x0         | INSTRU_STEP_FLAG<br>When finished 1 instruction, this bit will be set to 1.                                                                                                                                                                                                                                                                            |
| 16    | R          | 0x0         | INTSTRU_END_FLAG<br>When finished all instructions, this bit will be set to 1.                                                                                                                                                                                                                                                                         |
| 15:4  | /          | /           | /                                                                                                                                                                                                                                                                                                                                                      |
| 3     | R/W        | 0x0         | LINE_INT_EN<br>0: Disable<br>1: Enable<br>Enable Line interrupt.                                                                                                                                                                                                                                                                                       |
| 2     | R/W        | 0x0         | VB_INT_EN<br>0: Disable<br>1: Enable<br>Enable Vb interrupt.                                                                                                                                                                                                                                                                                           |

|   |     |     |                                                                                  |
|---|-----|-----|----------------------------------------------------------------------------------|
| 1 | R/W | 0x0 | INSTRU_STEP_EN<br>0: Disable<br>1: Enable<br>Enable instructions step interrupt. |
| 0 | R/W | 0x0 | INSTRU_END_EN<br>0: Disable<br>1: Enable<br>Enable instructions end interrupt.   |

#### 6.2.6.3. 0x0008 DSI Global Interrupt Register1(Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: DSI_GINT1_REG                            |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:13          | /          | /           | /                                                       |
| 12:0           | R/W        | 0x0         | LINE_INT_NUM<br>Set the trigger line of line interrupt. |

#### 6.2.6.4. 0x000C DSI Basic Control Register(Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: DSI_BASIC_CTL_REG                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:17          | /          | /           | /                                                                                                                            |
| 23:16          | R/W        | 0x0         | BRDY_SET<br>When using 4 lanes, set the delay time for module to deal with the data arrangement in data sub_package.         |
| 15:9           | /          | /           | /                                                                                                                            |
| 8              | R/W        | 0x0         | DSI_Start_Mode<br>0: Tri_Auto<br>1: Tri_By_TCON<br>Note that this bit is used for video mode and burst mode.                 |
| 7:4            | R/W        | 0x0         | TRAIL_INV<br>0000: Disable<br>0001: Enable<br>Others:Reserved<br>Enable trail inversion to deal with 4 lanes bytes aligning. |
| 3              | R/W        | 0x0         | TRAIL_FILL<br>0: Disable<br>1: Enable fill 2bytes as trail<br>Enable trail padding to deal with 4 lanes bytes aligning.      |
| 2              | R/W        | 0x0         | HBP_DIS<br>0: Normal mode<br>1: HBP disable                                                                                  |

|   |     |     |                                                                                                                              |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Disable HBP packets.                                                                                                         |
| 1 | R/W | 0x0 | HSA_HSE_DIS<br>0: Normal mode<br>1: HSA and HSE disable<br>Disable HSA packets and HSE packets.                              |
| 0 | R/W | 0x0 | VIDEO_MODE_BURST<br>0: Normal mode<br>1: Burst mode<br>Enable video burst mode.<br>When in burst mode, enter LP11 each line. |

#### 6.2.6.5. 0x0010 DSI Basic Control Register0(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DSI_BASIC_CTL0_REG                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:19          | /          | /           | /                                                                                                                                   |
| 18             | R/W        | 0x0         | HS_EOTP_EN<br>0: Disable<br>1: Enable<br>Enable Eotp packet at the end of every HS transmission.<br>Format: "08h" "0fh" "0fh" "01h" |
| 17             | R/W        | 0x0         | CRC_EN<br>0: Disable<br>1: Enable<br>Enable the CRC function.                                                                       |
| 16             | R/W        | 0x0         | ECC_EN<br>0: Disable<br>1: Enable<br>Enable the ECC function.                                                                       |
| 15:13          | /          | /           | /                                                                                                                                   |
| 12             | R/W        | 0x0         | FIFO_GATING<br>0: Disable<br>1: Enable<br>Gating data from TCON, note that TCON data is gating in frame unit.                       |
| 11             | /          | /           | /                                                                                                                                   |
| 10             | R/W        | 0x0         | FIFO_MANUAL_RESET<br>Write 1 to reset all correlation FIFO, writing 0 has no effect.                                                |
| 9:6            | /          | /           | /                                                                                                                                   |
| 5:4            | R/W        | 0x0         | SRC_SEL<br>00: TCON data<br>01: Test data<br>1x: Reserved<br>Select the data source of DSI.                                         |

|     |     |     |                                                                                                           |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------|
| 3:1 | /   | /   | /                                                                                                         |
| 0   | R/W | 0x0 | <p>INSTRU_EN<br/>0: Disable<br/>1: Enable<br/>When instruction enable, dsi process from instruction0.</p> |

#### 6.2.6.6. 0x0014 DSI Basic Control Register1(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: DSI_BASIC_CTL1_REG                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                 |
| 31:16          | R/W        | 0x0         | <p>TRI_DELAY<br/>It is used to set the delay of transmitting data from DSI in passive mode. That is, first delay to make the relevant FIFO have data, then transmit data to external device to avoid fifo empty.</p>                                                                                                                        |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                           |
| 11:4           | R/W        | 0x0         | <p>VIDEO_START_DELAY<br/>Delay by lines,only valid in video mode.<br/>The field is used in active mode. When DSI starts, DSI will delay by a certain number of rows before requesting data from TCON.<br/>The number of delayed row is decided by VIDEO_START_DELAY.<br/>Ensure that the number of delayed row is less than porch area.</p> |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x0         | <p>VIDEO_PRECISION_MODE_ALIGN<br/>0: Cut mode<br/>1: Fill mode<br/>In precision mode(set in VIDEO_FRAME_MODE), if the data length is not the integer times of lanes number, we should choose cut mode.</p>                                                                                                                                  |
| 1              | R/W        | 0x0         | <p>VIDEO_FRAME_MODE<br/>0: Normal mode<br/>1: Precision mode<br/>Set 0 to start new frame by instruction, and set 1 to start new frame by counter.</p>                                                                                                                                                                                      |
| 0              | R/W        | 0x0         | <p>DSI_MODE<br/>0: Command mode<br/>1: Video mode<br/>In video mode, enable timing define in basic size.</p>                                                                                                                                                                                                                                |

#### 6.2.6.7. 0x0018 DSI Basic Timing Register0(Default Value: 0x000A\_0000)

| Offset: 0x0018 |            |             | Register Name: DSI_BASIC_SIZE0_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:28          | /          | /           | /                                  |

|       |     |     |                                                      |
|-------|-----|-----|------------------------------------------------------|
| 27:16 | R/W | 0xa | VIDEO_VBP<br>Set the Vertical Blanking Porch length. |
| 15:12 | /   | /   | /                                                    |
| 11:0  | R/W | 0x0 | VIDEO_VSA<br>Set the Vertical Sync Area length.      |

#### 6.2.6.8. 0x001C DSI Basic Timing Register1(Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: DSI_BASIC_SIZE1_REG                 |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:29          | /          | /           | /                                                  |
| 28:16          | R/W        | 0x0         | VIDEO_VT<br>Set the Vertical Total length.         |
| 15:12          | /          | /           | /                                                  |
| 11:0           | R/W        | 0x0         | VIDEO_VACT<br>Set the Vertical Active Area Length. |

#### 6.2.6.9. 0x0020+N\*0x04 DSI Basic Instruction Register0(Default Value: 0x0000\_0000)

| Offset: 0x0020+N*0x04(N=0,1,2,3,4,5,6,7) |            |             | Register Name: DSI_BASIC_INST0_REG                                                                                                                                                                              |
|------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                      | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:28                                    | R/W        | 0x0         | INSTRU_MODE<br>000: Stop(LP-11)<br>001: BTA(Bus Turn Around)<br>010: HS(High Speed mode)<br>011: Escape Mode<br>100: HS Exit(only use in clk lane)<br>101: Nop<br>Others: reserved<br>Set the instruction type. |
| 27:24                                    | R/W        | 0x0         | ESCAPE_ENRTY<br>000: LPDT<br>001: ULPS<br>010: Undef-1<br>011: Undef-2<br>100: Trigger-Reset<br>101: Undef-3<br>110: Undef-4<br>111: Undef-5<br>Others: reserved<br>Set the Escape entry code,valid in Escape.  |
| 23:20                                    | R/W        | 0x0         | TRANS_PACKET                                                                                                                                                                                                    |

|       |     |     |                                                                                                                                                                                                                                                                                                  |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 000: Pixel Packet<br>001: Command Packet<br>010: Pixel + Sync + Blk Packet<br>Others: reserved<br>Valid in HS or Escape LPDT.                                                                                                                                                                    |
| 19:16 | R/W | 0x0 | TRANS_START_CONDITION<br>000: Immediate, used in cmd_tx<br>001: Trans FIFO ready TRANS_FIFO_NUM, used in command mode<br>010: TCON Hsync delay DSI_DELAY_CYCLE, used in video mode<br>011: DSI HT end, DSI new line start, used in video mode<br>Others: reserved<br>Valid in HS or Escape LPDT. |
| 15:5  | /   | /   | /                                                                                                                                                                                                                                                                                                |
| 4:0   | R/W | 0x0 | LANE_SEL<br>Bit4: clk lane selected<br>Bit3: data3 lane selected<br>Bit2: data2 lane selected<br>Bit1: data1 lane selected<br>Bit0: data0 lane selected<br>0: Disable<br>1: Enable<br>Instruction is valid on selected lane.                                                                     |

#### 6.2.6.10. 0x0040 DSI Basic Instruction Register1(Default Value: 0x0000\_0000)

| Offset: 0x0040 |            | Register Name: DSI_BASIC_INST1_REG |                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex                        | Description                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0           | R/W        | 0x0                                | LOOP_SEL<br>Bit31-28: Instruction7<br>Bit27-24: Instruction6<br>Bit23-20: Instruction5<br>Bit19-16: Instruction4<br>Bit15-12: Instruction3<br>Bit11-08: Instruction2<br>Bit07-04: Instruction1<br>Bit03-00: Instruction0<br>000: only one times<br>010: (LOOP_N0+1) times<br>011: (LOOP_N1+1) times<br>Others: reserved<br>Note LOOP_N0, LOOP_N1 is defined in DSI_BASIC_INST2_REG. |

#### 6.2.6.11. 0x0044 DSI Basic Instruction Register2(Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: DSI_BASIC_INST2_REG                          |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:28          | /          | /           | /                                                           |
| 27:16          | R/W        | 0x0         | LOOP_N1<br>Set the instructions loop time in blanking area. |
| 15:12          | /          | /           | /                                                           |
| 11:0           | R/W        | 0x0         | LOOP_N0<br>Set the instructions loop time in blanking area. |

#### 6.2.6.12. 0x0048 DSI Basic Instruction Register3(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: DSI_BASIC_INST3_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:28          | R/W        | 0x0         | INST7_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27:24          | R/W        | 0x0         | INST6_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:20          | R/W        | 0x0         | INST5_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 19:16          | R/W        | 0x0         | INST4_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:12          | R/W        | 0x0         | INST3_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:8           | R/W        | 0x0         | INST2_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:4            | R/W        | 0x0         | INST1_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:0            | R/W        | 0x0         | INST0_JUMP_SEL<br>Bit31-28: Instruction7<br>Bit27-24: Instruction6<br>Bit23-20: Instruction5<br>Bit19-16: Instruction4<br>Bit15-12: Instruction3<br>Bit11-08: Instruction2<br>Bit07-04: Instruction1<br>Bit03-00: Instruction0<br>0000: Jump Instruction0<br>0001: Jump Instruction1<br>0010: Jump Instruction2<br>0011: Jump Instruction3<br>0100: Jump Instruction4<br>0101: Jump Instruction5<br>0110: Jump Instruction6<br>0111: Jump Instruction7<br>1000: Jump Instruction8<br>1001: Jump Instruction9<br>1010: Jump Instruction10<br>1011: Jump Instruction11 |

|  |  |  |                                                                                                                                                      |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 1100: Jump Instruction12<br>1101: Jump Instruction13<br>1110: Jump Instruction14<br>1111: Jump End<br>Others: reserved<br>Set the instruction order. |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 6.2.6.13. 0x004C DSI Basic Instruction Register4(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: DSI_BASIC_INST4_REG                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:29          | /          | /           | /                                                                                               |
| 28             | R/W        | 0x0         | JUMP_CFG0_EN<br>0:Disable instructions jump function<br>1:Enable instructions jump function     |
| 27:24          | /          | /           | /                                                                                               |
| 23:20          | R/W        | 0x0         | JUMP_CFG0_TO<br>Set the instruction which will be jumped after finishing the instructions loop. |
| 19:16          | R/W        | 0x0         | JUMP_CFG0_POINT<br>Set the entry instruction of the instructions loop.                          |
| 15:0           | R/W        | 0x0         | JUMP_CFG0_NUM<br>Set the loop time of the instructions loop.                                    |

#### 6.2.6.14. 0x0050 DSI Basic Instruction Register5(Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: DSI_BASIC_INST5_REG                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:29          | /          | /           | /                                                                                               |
| 28             | R/W        | 0x0         | JUMP_CFG1_EN<br>0:Disable instructions jump function<br>1:Enable instructions jump function     |
| 27:24          | /          | /           | /                                                                                               |
| 23:20          | R/W        | 0x0         | JUMP_CFG1_TO<br>Set the instruction which will be jumped after finishing the instructions loop. |
| 19:16          | R/W        | 0x0         | JUMP_CFG1_POINT<br>Set the entry instruction of the instructions loop.                          |
| 15:0           | R/W        | 0x0         | JUMP_CFG1_NUM<br>Set the loop time of the instructions loop.                                    |

#### 6.2.6.15. 0x0054 DSI Basic Instruction Register6(Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: DSI_BASIC_INST6_REG                                     |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:28          | /          | /           | /                                                                      |
| 27:16          | R/W        | 0x0         | LOOP_N1_SHADOW<br>In video burst mode, replace LOOP_N1 in active area. |
| 15:12          | /          | /           | /                                                                      |
| 11:0           | R/W        | 0x0         | LOOP_N0_SHADOW<br>In video burst mode, replace LOOP_N0 in active area. |

#### 6.2.6.16. 0x0060 DSI Basic Transmission Register0(Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: DSI_BASIC_TRAN0_REG                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31:13          | /          | /           | /                                                                                                                |
| 12:0           | R/W        | 0x0         | TRANS_START_SET<br>In video mode, hs tx by timing start.<br>In command mode, hs tx when fifo reach this numbers. |

#### 6.2.6.17. 0x0078 DSI Basic Transmission Register4(Default Value: 0x0000\_0000)

| Offset: 0x0078 |            |             | Register Name: DSI_BASIC_TRAN4_REG                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:0           | R/W        | 0x0         | HS_ZERO_REDUCE_SET<br>Setting a value to reduce HS Zero time.Delay time to info D-PHY into HS.<br>TRANS_START_SET- HS_ZERO_REDUCE_SET = DSI_HS_ZERO_TIME.<br>Total hs zero time = DSI_HS_ZERO_TIME + DPHY_HS_ZERO_TIME.<br>It should be HS_ZERO_REDUCE_SET < (TRANS_START_SET-30).<br>Note that HS_ZERO_REDUCE_SET should be 7 hsbyte clk earlier than TRANS_START_SET, and this value is refer to lp clk.<br>If hs=300M, lp=150M, $(1/300) \times 8 \times 7 \div (1/150) = 28$ |

#### 6.2.6.18. 0x007C DSI Basic Transmission Register5(Default Value: 0x0000\_0000)

| Offset: 0x007C |            |             | Register Name: DSI_BASIC_TRAN5_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:29          | /          | /           | /                                  |
| 28             | R/W        | 0x0         | DRQ_MODE                           |

|       |     |     |                                                                                                                       |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: Request tcon data at new line start<br>1: Request tcon data reference to Drq_set<br>Set the DRQ request condition. |
| 27:10 | /   | /   | /                                                                                                                     |
| 9:0   | R/W | 0x0 | DRQ_SET<br>Request tcon data reference setting, this bit is only valid when DRQ_MODE='1'.                             |

#### 6.2.6.19. 0x0080 DSI Pixel Control Register0(Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: DSI_PIXEL_CTL0_REG                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 16             | R/W        | 0x0         | PD_PLUG_DIS<br>Disable PD plug before pixel bytes.                                                                                                                                                                                                                   |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                                    |
| 4              | R/W        | 0x0         | PIXEL_ENDIAN<br>0: LSB first<br>1: MSB first<br>Set the endian of the pixel data.                                                                                                                                                                                    |
| 3:0            | R/W        | 0x0         | PIXEL_FORMAT<br>Command mode<br>0000: 24-bit (rgb888)<br>0001: 18-bit (rgb666)<br>0010: 16-bit (rgb565)<br>Video mode<br>1000: 24-bit(rgb888)<br>1001: 18-bit(rgb666L)<br>1010: 18-bit (rgb666)<br>1011: 16-bit(rgb565)<br>Others: reserved<br>Set the pixel format. |

#### 6.2.6.20. 0x0090 DSI Pixel Packet Header Register(Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: DSI_PIXEL_PH_REG                   |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:24          | R/W        | 0x0         | ECC<br>Only valid when DSI ECC is disable.        |
| 23:8           | R/W        | 0x0         | WC<br>WC is byte numbers of PD in a pixel packet. |
| 7:6            | R/W        | 0x0         | VC                                                |

|     |     |     |                                                                                                                                                                               |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | Virtual Channel.                                                                                                                                                              |
| 5:0 | R/W | 0x0 | DT<br>Video mode 24-bit, set as "3eh"<br>Video mode L18-bit, set as "2eh"<br>Video mode 18-bit, set as "1eh"<br>Video mode 16-bit, set as "0eh"<br>Command mode, set as "39h" |

#### 6.2.6.21. 0x0094 DSI Pixel Packet Data Register(Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: DSI_PIXEL_PD_REG                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:24          | /          | /           | /                                                                                                                 |
| 23:16          | R/W        | 0x0         | <b>PD_TRANN</b><br>Used in transmissions except 1st one, set as "3Ch", only valid when PD_PLUG_DIS is set to '0'. |
| 15:8           | /          | /           | /                                                                                                                 |
| 7:0            | R/W        | 0x0         | <b>PD_TRANO</b><br>Used in 1st transmission, set as "2Ch", only valid when PD_PLUG_DIS is set to '0'.             |

#### 6.2.6.22. 0x0098 DSI Pixel Packet Footer Register0(Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: DSI_PIXEL_PFO_REG                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:16          | /          | /           | /                                                                                           |
| 15:0           | R/W        | 0x0         | <b>CRC_FORCE</b><br>CRC force to this value, this value is only valid when CRC is disabled. |

#### 6.2.6.23. 0x009C DSI Pixel Packet Footer Register1(Default Value: 0xFFFF\_FFFF)

| Offset: 0x009C |            |             | Register Name: DSI_PIXEL_PF1_REG                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:16          | R/W        | 0xffff      | <b>CRC_INIT_LINE_N</b><br>CRC initial to this value in transmissions except 1st one,only valid when CRC is enabled.  |
| 15:0           | R/W        | 0xffff      | <b>CRC_INIT_LINE_O</b><br>CRC initial to this value in 1st transmission every frame, only valid when CRC is enabled. |

#### 6.2.6.24. 0x00B0 DSI H Sync Start Register(Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: DSI_SYNC_HSS_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:24          | R/W        | 0x0         | ECC<br>Set as "12h".            |
| 23:16          | R/W        | 0x0         | D1<br>Set as "00h".             |
| 15:8           | R/W        | 0x0         | D0<br>Set as "00h".             |
| 7:6            | R/W        | 0x0         | VC<br>Virtual Channel.          |
| 5:0            | R/W        | 0x0         | DT<br>HSS, set as "21h".        |

#### 6.2.6.25. 0x00B4 DSI H Sync End Register(Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: DSI_SYNC_HSE_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:24          | R/W        | 0x0         | ECC<br>Set as "01h".            |
| 23:16          | R/W        | 0x0         | D1<br>Set as "00h".             |
| 15:8           | R/W        | 0x0         | D0<br>Set as "00h".             |
| 7:6            | R/W        | 0x0         | VC<br>Virtual Channel.          |
| 5:0            | R/W        | 0x0         | DT<br>HSE, set as "31h".        |

#### 6.2.6.26. 0x00B8 DSI V Sync Start Register(Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: DSI_SYNC_VSS_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:24          | R/W        | 0x0         | ECC<br>Set as "07h".            |
| 23:16          | R/W        | 0x0         | D1<br>Set as "00h".             |
| 15:8           | R/W        | 0x0         | D0<br>Set as "00h".             |
| 7:6            | R/W        | 0x0         | VC<br>Virtual Channel.          |

|     |     |     |                          |
|-----|-----|-----|--------------------------|
| 5:0 | R/W | 0x0 | DT<br>VSS, set as "01h". |
|-----|-----|-----|--------------------------|

#### 6.2.6.27. 0x00BC DSI V Sync End Register(Default Value: 0x0000\_0000)

| Offset: 0x00BC |            |             | Register Name: DSI_SYNC_VSE_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:24          | R/W        | 0x0         | ECC<br>Set as "14h".            |
| 23:16          | R/W        | 0x0         | D1<br>Set as "00h".             |
| 15:8           | R/W        | 0x0         | D0<br>Set as "00h".             |
| 7:6            | R/W        | 0x0         | VC<br>Virtual Channel.          |
| 5:0            | R/W        | 0x0         | DT<br>VSE, set as "11h".        |

#### 6.2.6.28. 0x00C0 DSI Blanking H Sync Active Register0(Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: DSI_BLK_HSA0_REG                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:0           | R/W        | 0x0         | HSA_PH<br>Note that bit23:8 is WC, define byte numbers of PD in a blank packet.<br>Set the packet header value of HSA packets. |

#### 6.2.6.29. 0x00C4 DSI Blanking H Sync Active Register1(Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: DSI_BLK_HSA1_REG                       |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:16          | R/W        | 0x0         | HSA_PF<br>Set the packet footer value of HSA packets. |
| 15:8           | /          | /           | /                                                     |
| 7:0            | R/W        | 0x0         | HSA_PD<br>Set the packet value of HSA packets.        |

#### 6.2.6.30. 0x00C8 DSI Blanking H Back Porch Register0(Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: DSI_BLK_HBP0_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |

|      |     |     |                                                                                                                                |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W | 0x0 | HBP_PH<br>Note that bit23:8 is WC, define byte numbers of PD in a blank packet.<br>Set the packet header value of HBP packets. |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------|

#### 6.2.6.31. 0x00CC DSI Blanking H Back Porch Register0(Default Value: 0x0000\_0000)

| Offset: 0x00CC |            |             | Register Name: DSI_BLK_HBP1_REG                       |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:16          | R/W        | 0x0         | HBP_PF<br>Set the packet footer value of HBP packets. |
| 15:8           | /          | /           | /                                                     |
| 7:0            | R/W        | 0x0         | HBP_PD<br>Set the packet value of HBP packets.        |

#### 6.2.6.32. 0x00D0 DSI Blanking H Front Porch Register0(Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: DSI_BLK_HFP0_REG                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:0           | R/W        | 0x0         | HFP_PH<br>Note that bit[23:8] is WC, define byte numbers of PD in a blank packet.<br>Set the packet header value of HFP packets. |

#### 6.2.6.33. 0x00D4 DSI Blanking H Front Porch Register1(Default Value: 0x0000\_0000)

| Offset: 0x00D4 |            |             | Register Name: DSI_BLK_HFP1_REG                       |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:16          | R/W        | 0x0         | HFP_PF<br>Set the packet footer value of HFP packets. |
| 15:8           | /          | /           | /                                                     |
| 7:0            | R/W        | 0x0         | HFP_PD<br>Set the packet value of HFP packets.        |

#### 6.2.6.34. 0x00E0 DSI H Blanking Register0(Default Value: 0x0000\_0000)

| Offset: 0x00E0 |            |             | Register Name: DSI_BLK_HBLK0_REG                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:0           | R/W        | 0x0         | HBLK_PH<br>Note that bit[23:8] is WC, define byte numbers of PD in a blank packet.<br>Set the packet header value of HBLK packets. |

#### 6.2.6.35. 0x00E4 DSI H Blanking Register1(Default Value: 0x0000\_0000)

| Offset: 0x00E4 |            |             | Register Name: DSI_HBLK_BLK1_REG                        |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:16          | R/W        | 0x0         | HBLK_PF<br>Set the packet footer value of HBLK packets. |
| 15:8           | /          | /           | /                                                       |
| 7:0            | R/W        | 0x0         | HBLK_PD<br>Set the packet value of HBLK packets.        |

#### 6.2.6.36. 0x00E8 DSI V Blanking Register0(Default Value: 0x0000\_0000)

| Offset: 0x00E8 |            |             | Register Name: DSI_BLK_VBLK0_REG                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:0           | R/W        | 0x0         | VBLK_PH<br>Note that bit[23:8] is WC, define byte numbers of PD in a blank packet.<br>Set the packet header value of VBLK packets. |

#### 6.2.6.37. 0x00EC DSI V Blanking Register1(Default Value: 0x0000\_0000)

| Offset: 0x00EC |            |             | Register Name: DSI_BLK_VBLK1_REG                        |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:16          | R/W        | 0x0         | VBLK_PF<br>Set the packet footer value of VBLK packets. |
| 15:8           | /          | /           | /                                                       |
| 7:0            | R/W        | 0x0         | VBLK_PD<br>Set the packet value of VBLK packets.        |

#### 6.2.6.38. 0x00F0 DSI Burst Line Register(Default Value: 0x0000\_0000)

| Offset: 0x00F0 |            |             | Register Name: DSI_BRUST_LINE_REG                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31:16          | R/W        | 0x0         | LINE_SYNCPOINT<br>In video burst mode, set the start time of the first HS data transmission. It is set as 30 by default . |
| 15:0           | R/W        | 0x0         | LINE_NUM<br>In video burst mode, set the total time of each line whose unit the cycle of symbol.                          |

#### 6.2.6.39. 0x00F4 DSI Burst DRQ Register(Default Value: 0x0000\_0000)

| Offset: 0x00F4 |            |             | Register Name: DSI_BRUST_DRQ_REG                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 31:16          | R/W        | 0x0         | DRQ_EDGE1<br>In video burst mode, DRQ_EDGE0 and DRQ_EDGE1 is used to control the create time of dsi_drq. There is a timer working during burst mode. If DRQ_EDGE1 < timer value < DRQ_EDGE0, the dsi_drq will be set 1. |
| 15:0           | R/W        | 0x0         | DRQ_EDGE0<br>In video burst mode, DRQ_EDGE0 and DRQ_EDGE1 is used to control the create time of dsi_drq. There is a timer working during burst mode. If DRQ_EDGE1 < timer value < DRQ_EDGE0, the dsi_drq will be set 1. |

#### 6.2.6.40. 0x00FC DSI Debug Register(Default Value: 0x0000\_0000)

| Offset: 0x00FC |            |             | Register Name: DSI_DEBUG_REG                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31             | R          | 0x0         | DSI_FIFO_UNDER_FLOW<br>It will be set 1 when the DSI FIFO is underflow. |
| 30:0           | /          | /           | /                                                                       |

#### 6.2.6.41. 0x0120+N\*0x04 DSI Basic INST10 Register(Default Value: 0x0000\_0000)

| Offset: 0x0120+N*0x04(N=0,1,2,3,4,5,6) |            |             | Register Name: DSI_BASIC_INST10_REG                                                                                                                  |
|----------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                    | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:28                                  | R/W        | 0           | Instru_Mode<br>0000: Stop(LP-11)<br>0001: TBA<br>0010: HS-NM<br>0011: Escape<br>0100: HS Exit(only use in clk lane)<br>0101: Nop<br>Others: reserved |
| 27:24                                  | R/W        | 0           | Escape_Enrt<br>0000: LPDT<br>0001: ULPS<br>0010: Undef-1<br>0011: Undef-2<br>0100: Trigger-Reset<br>0101: Undef-3<br>0110: Undef-4<br>0111: Undef-5  |

|       |     |   |                                                                                                                                                                                                                                                                                                      |
|-------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | Others: reserved<br>valid in Escape.                                                                                                                                                                                                                                                                 |
| 23:20 | R/W | 0 | Trans_Packet<br>0000: Pixel Packet<br>0001: Command Packet<br>0010: Pixel + Sync + Blk Packet<br>Others: reserved<br>Valid in HS or Escape LPDT.                                                                                                                                                     |
| 19:16 | R/W | 0 | Trans_Start_Condition<br>0000: Immediate, used in cmd_tx<br>0001: Trans FIFO ready Trans_FIFO_Num, used in command mode<br>0010: TCON hsync delay DSI_Delay_Cycle, used in video mode<br>0011: DSI HT end, DSI new line start, used in video mode<br>Others: reserved<br>Valid in HS or Escape LPDT. |
| 15:5  | /   | / | /                                                                                                                                                                                                                                                                                                    |
| 4:0   | R/W | 0 | Lane_Sel<br>Bit4: clk lane selected<br>Bit3: data3 lane selected<br>Bit2: data2 lane selected<br>Bit1: data1 lane selected<br>Bit0: data0 lane selected<br>0: disable<br>1: enable<br>Instruction is valid on selected lane.                                                                         |

#### 6.2.6.42. 0x0140 DSI Basic INST11 Register(Default Value: 0x0000\_0000)

| Offset: 0x0140 |            |             | Register Name: DSI_BASIC_INST11_REG                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0           | R/W        | 0x0         | LOOP_SEL<br>Bit31-28: Instruction15<br>Bit27-24: Instruction14<br>Bit23-20: Instruction13<br>Bit19-16: Instruction12<br>Bit15-12: Instruction11<br>Bit11-08: Instruction10<br>Bit07-04: Instruction9<br>Bit03-00: Instruction8<br>0: only one times<br>2: (Loop_N0+1) times<br>3: (Loop_N1+1) times<br>Others: reserved<br>Note Loop_N0, Loop_N1 is defined in DSI_BASIC_INST2_REG |

#### 6.2.6.43. 0x0148 DSI Basic INST13 Register(Default Value: 0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: DSI_BASIC_INST13_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 27:24          | R/W        | 0x0         | INST14_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23:20          | R/W        | 0x0         | INST13_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19:16          | R/W        | 0x0         | INST12_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:12          | R/W        | 0x0         | INST11_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:8           | R/W        | 0x0         | INST10_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:4            | R/W        | 0x0         | INST9_JUMP_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:0            | R/W        | 0x0         | INST8_JUMP_SEL<br>Bit31-28: Instruction7<br>Bit27-24: Instruction6<br>Bit23-20: Instruction5<br>Bit19-16: Instruction4<br>Bit15-12: Instruction3<br>Bit11-08: Instruction2<br>Bit07-04: Instruction1<br>Bit03-00: Instruction0<br>0000: Jump Instruction0<br>0001: Jump Instruction1<br>0010: Jump Instruction2<br>0011: Jump Instruction3<br>0100: Jump Instruction4<br>0101: Jump Instruction5<br>0110: Jump Instruction6<br>0111: Jump Instruction7<br>1000: Jump Instruction8<br>1001: Jump Instruction9<br>1010: Jump Instruction10<br>1011: Jump Instruction11<br>1100: Jump Instruction12<br>1101: Jump Instruction13<br>1110: Jump Instruction14<br>1111: Jump End<br>Others: reserved<br>Set the instruction order. |

#### 6.2.6.44. 0x01F0 DSI Safe Period Register(Default Value: 0x0000\_0000)

| Offset: 0x01F0 | Register Name: DSI_SAFE_PERIOD_REG |
|----------------|------------------------------------|
|----------------|------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                   |
|-------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | /          | /           | /                                                                                                                                                                             |
| 28:16 | R/W        | 0x0         | SAFE_PERIOD_FIFO_NUM<br>When the data length in line buffer is more than SAFE_PERIOD_FIFO_NUM, DSI controller will allow dram controller to stop working to change frequency. |
| 15:4  | R/W        | 0x0         | SAFE_PERIOD_LINE<br>Set a fixed line and during the line time, DSI controller allow dram controller to change frequency. The fixed line should be set in the blanking area.   |
| 3     | /          | /           | /                                                                                                                                                                             |
| 2:0   | R/W        | 0x0         | SAFE_PERIOD_MODE<br>000: unsafe<br>001: safe<br>010: safe at FIFO_CURR_NUM > SAFE_PERIOD_FIFO_NUM<br>011: safe at 2 and safe at sync active<br>100: safe at line              |

#### 6.2.6.45. 0x0200 DSI Command Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: DSI_CMD_CTL_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:25          | /          | /           | /                                                                                                                      |
| 26             | R/W        | 0x0         | RX_OVERFLOW<br>1: rx data is overflow register buffer<br>Note: Write '1' to clear this bit. Writing '0' has no effect. |
| 25             | R/W        | 0x0         | RX_FLAG<br>1: rx has happened<br>Note: Write '1' to clear this bit. Writing '0' has no effect.                         |
| 24             | R          | 0x0         | RX_STATUS<br>0: rx is finish<br>1: rx is pending                                                                       |
| 20:16          | R          | 0x0         | RX_SIZE<br>(RX_SIZE+1) is number of bytes in the last rx.                                                              |
| 15:9           | /          | /           | /                                                                                                                      |
| 9              | R/W        | 0x0         | TX_FLAG<br>1: tx has happened<br>Note: Write '1' to clear this bit. Writing '0' has no effect.                         |
| 8              | R          | 0x0         | TX_STATUS<br>0: tx is finish<br>1: tx is pending                                                                       |
| 7:0            | R/W        | 0x0         | TX_SIZE<br>(TX_SIZE+1) is number of bytes ready to tx                                                                  |

#### 6.2.6.46. 0x0240+N\*0x04 DSI Command RX Register(Default Value: 0x0000\_0000)

| Offset: 0x0240+N*0x04(N=0,1,2,3,4,5,6,7) |            |             | Register Name: DSI_CMD_RX_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                      | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0                                     | R          | 0x0         | <p>DATA</p> <p>Bit: 31:24 23:16 15:8 7:0</p> <p>N=0: Byte03 Byte02 Byte01 Byte00</p> <p>N=1: Byte07 Byte06 Byte05 Byte04</p> <p>N=2: Byte11 Byte10 Byte09 Byte08</p> <p>N=3: Byte15 Byte14 Byte13 Byte12</p> <p>N=4: Byte19 Byte18 Byte17 Byte16</p> <p>N=5: Byte23 Byte22 Byte21 Byte20</p> <p>N=6: Byte27 Byte26 Byte25 Byte24</p> <p>N=7: Byte31 Byte30 Byte29 Byte28</p> <p>Data from rx, only in LPDT</p> <p>Only read when RX_Flag is setting. no way to clear this fifo.</p> |

#### 6.2.6.47. 0x0300+N\*0x04 DSI Command TX Register(Default Value: 0x0000\_0000)

| Offset: 0x0300+N*0x04(N=0,1,2...64) |            |             | Register Name: DSI_CMD_TX_REG                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                 | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0                                | R/W        | 0x0         | <p>DATA</p> <p>Bit: 31:24 23:16 15:8 7:0</p> <p>N=0: Byte03 Byte02 Byte01 Byte00</p> <p>N=1: Byte07 Byte06 Byte05 Byte04</p> <p>N=2: Byte11 Byte10 Byte09 Byte08</p> <p>N=3: Byte15 Byte14 Byte13 Byte12</p> <p>N=4: Byte19 Byte18 Byte17 Byte16</p> <p>N=5: Byte23 Byte22 Byte21 Byte20</p> <p>N=6: Byte27 Byte26 Byte25 Byte24</p> <p>N=7: Byte31 Byte30 Byte29 Byte28</p> <p>Data for tx, transmission in HS and LPDT, defined by INST_REG.</p> |

#### 6.2.6.48. 0x02E0 DSI Debug Register0(Default Value: 0x0000\_0000)

| Offset: 0x02E0 |            |             | Register Name: DSI_DEBUG0_REG                             |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:13          | /          | /           | /                                                         |
| 12:0           | R          | 0x0         | <p>VIDEO_CURR_LINE</p> <p>The real time current line.</p> |

#### 6.2.6.49. 0x02E4 DSI Debug Register1(Default Value: 0x0000\_0000)

| Offset: 0x02E4 |            |             | Register Name: DSI_DEBUG1_REG                                    |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:0           | R          | 0x0         | VIDEO_CURR_LP2HS<br>The current number of LP to HS in real time. |

#### 6.2.6.50. 0x02EC DSI INST Debug Register(Default Value: 0x0000\_0000)

| Offset: 0x02EC |            |             | Register Name: DSI_INST_DEBUG_REG                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:15          | /          | /           | /                                                                               |
| 14             | R/W        | 0x0         | INSTRU14_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect. |
| 13             | R/W        | 0x0         | INSTRU13_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect. |
| 12             | R/W        | 0x0         | INSTRU12_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect. |
| 11             | R/W        | 0x0         | INSTRU11_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect. |
| 10             | R/W        | 0x0         | INSTRU10_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect. |
| 9              | R/W        | 0x0         | INSTRU9_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 8              | R/W        | 0x0         | INSTRU8_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 7              | R/W        | 0x0         | INSTRU7_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 6              | R/W        | 0x0         | INSTRU6_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 5              | R/W        | 0x0         | INSTRU5_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 4              | R/W        | 0x0         | INSTRU4_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 3              | R/W        | 0x0         | INSTRU3_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 2              | R/W        | 0x0         | INSTRU2_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 1              | R/W        | 0x0         | INSTRU1_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |
| 0              | R/W        | 0x0         | INSTRU0_UNKNOW_FLAG<br>Write '1' to clear this bit. Writing '0' has no effect.  |

#### 6.2.6.51. 0x02F0 DSI Debug Register2(Default Value: 0x0000\_0000)

| Offset: 0x02F0 |            |             | Register Name: DSI_DEBUG2_REG                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:23          | /          | /           | /                                                                                                                 |
| 23:20          | R          | 0x0         | CURR_INSTRU_NUM<br>Instruction number process now.                                                                |
| 19:4           | R          | 0x0         | CURR_LOOP_NUM<br>The loop number of instructions loop.                                                            |
| 3:2            | /          | /           | /                                                                                                                 |
| 1              | R/W        | 0x0         | TRANS_FAST_FLAG<br>When in active region, transmit FIFO is empty, this bit is set. Write '1' to clear this bit.   |
| 0              | R/W        | 0x0         | TRANS_LOW_FLAG<br>Before trans FIFO reset, trans FIFO is not empty, this bit is set. Write '1' to clear this bit. |

#### 6.2.6.52. 0x02F4 DSI Debug Register3(Default Value: 0x0000\_0000)

| Offset: 0x02F4 |            |             | Register Name: DSI_DEBUG3_REG                    |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:16          | R          | 0x0         | CURR_FIFO_NUM<br>Byte numbers in trans FIFO now. |
| 15:0           | /          | /           | /                                                |

#### 6.2.6.53. 0x02F8 DSI Debug Register4(Default Value: 0x0000\_0000)

| Offset: 0x02F8 |            |             | Register Name: DSI_DEBUG4_REG                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:29          | /          | /           | /                                                                                          |
| 28             | R/W        | 0x0         | DSI_FIFO_BIST_EN<br>0: Disable<br>1: Enable<br>Entry address is 0xFF8.                     |
| 27:24          | /          | /           | /                                                                                          |
| 23:0           | R/W        | 0x0         | TEST_DATA<br>Cooperated with SRC_SEL in DSI_BASIC_CTL0_REG, instead of the data from TCON. |

#### 6.2.6.54. 0x1000 DPHY Control Register(Default Value: 0x0000\_0000)

| Offset:0x1000 |            |             | Register Name: DPHY_CTL_REG                                                                                                                                             |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:6          | /          | /           | /                                                                                                                                                                       |
| 5:4           | R/W        | 0x0         | <p>LANE_NUM<br/>000: 1 data lane<br/>001: 2 data lane<br/>010: 3 data lane<br/>011: 4 data lane</p> <p>Note: This bits determine lane number used for transmission.</p> |
| 3:1           | /          | /           | /                                                                                                                                                                       |
| 0             | R/W        | 0x0         | <p>MODULE_EN<br/>0: Disable<br/>1: Enable</p> <p>When it is disabled, the module will be reset to idle state.</p>                                                       |

#### 6.2.6.55. 0x1004 DPHY TX Control Register(Default Value: 0x0000\_0000)

| Offset:0x1004 |            |             | Register Name: DPHY_TX_CTL_REG                                                                                                                                          |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:30         | /          | /           | /                                                                                                                                                                       |
| 29            | R/W        | 0x0         | <p>ULPSTX_ENTER<br/>0: Direct (enter LP-00 after ULPS command)<br/>1: Indirect (enter MARK-I after ULPS command then LP-00)</p>                                         |
| 28            | R/W        | 0x0         | <p>HSTX_CLK_CONT<br/>0: Disable<br/>1: Enable</p> <p>When this bit is enabled, clk lane continue in HS mode. When this bit is disable, clk lane anto enter LP mode.</p> |
| 27:26         | /          | /           | /                                                                                                                                                                       |
| 25            | R/W        | 0x0         | <p>HSTX_CLK_EXIT<br/>0: No effect<br/>1: Force clock lane exit from HS</p>                                                                                              |
| 24            | R/W        | 0x0         | <p>HSTX_DATA_EXIT<br/>0: No effect<br/>1: Force all data lanes exit from HS</p>                                                                                         |
| 23:21         | /          | /           | /                                                                                                                                                                       |
| 20            | R/W        | 0x0         | <p>ULPSTX_CLK_EXIT<br/>0: No effect<br/>1: Force Clock lane exit from ULPS</p>                                                                                          |
| 19            | R/W        | 0x0         | <p>ULPSTX_DATA3_EXIT<br/>0: No effect</p>                                                                                                                               |

|       |     |     |                                                                                          |
|-------|-----|-----|------------------------------------------------------------------------------------------|
|       |     |     | 1: Force data lane 3 exit from ULPS                                                      |
| 18    | R/W | 0x0 | ULPSTX_DATA2_EXIT<br>0: No effect<br>1: Force data lane 2 exit from ULPS                 |
| 17    | R/W | 0x0 | ULPSTX_DATA1_EXIT<br>0: No effect<br>1: Force data lane 1 exit from ULPS                 |
| 16    | R/W | 0x0 | ULPSTX_DATA0_EXIT<br>0: No effect<br>1: Force data lane 0 exit from ULPS                 |
| 15:13 | /   | /   | /                                                                                        |
| 12    | R/W | 0x0 | FORCE_LP11<br>0: No effect<br>1: Force module work in LP11                               |
| 11    | R/W | 0x0 | HSTX_8B9B_EN<br>0: 8B9B Encoding disable<br>1: 8B9B Encoding enable                      |
| 10    | R/W | 0x0 | LPTX_8B9B_EN<br>0: 8B9B Encoding disable<br>1: 8B9B Encoding enable                      |
| 9     | R/W | 0x0 | HSTX_ENDIAN<br>0: LSB first<br>1: MSB first                                              |
| 8     | R/W | 0x0 | LPTX_ENDIAN<br>0: LSB first<br>1: MSB first                                              |
| 7:5   | /   | /   | /                                                                                        |
| 4     | R/W | 0x0 | TX_CLK_FORCE<br>Write 1 to force into tx default state(lp00)<br>Writing 0 has no effect. |
| 3     | R/W | 0x0 | TX_D3_FORCE<br>Write 1 to force into tx default state(lp00)<br>Writing 0 has no effect.  |
| 2     | R/W | 0x0 | TX_D2_FORCE<br>Write 1 to force into tx default state(lp00)<br>Writing 0 has no effect.  |
| 1     | R/W | 0x0 | TX_D1_FORCE<br>Write 1 to force into tx default state(lp00)<br>Writing 0 has no effect.  |
| 0     | R/W | 0x0 | TX_D0_FORCE<br>Write 1 to force into tx default state(lp00)<br>Writing 0 has no effect.  |

#### 6.2.6.56. 0x1010 DPHY TX Timing Parameter 0 Register(Default Value: 0x0000\_0000)

| Offset:0x1010 |            |             | Register Name: DPHY_TX_TIME0_REG                                                                   |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                        |
| 31:24         | R/W        | 0x0         | HS_TRAIL_SET<br>HS trail = (HS_TRAIL_SET + 2) * Tbyteclk + (2~3)*Tclk - (3~4)*Tclkd8.              |
| 23:16         | R/W        | 0x0         | HS_PRE_SET<br>The setting of hs prepare time:<br>Begin with LP00, end after (HS_PRE_SET + 4)*Tclk. |
| 15:8          | /          | /           | /                                                                                                  |
| 7:0           | R/W        | 0x0         | LPX_TM_SET<br>LP pulse = (LPX_TM_SET + 1)*Tclk.                                                    |

#### 6.2.6.57. 0x1014 DPHY TX Timing Parameter 1 Register(Default Value: 0x0000\_0000)

| Offset:0x1014 |            |             | Register Name: DPHY_TX_TIME1_REG                                                                                                      |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:24         | R/W        | 0x0         | CK_POST_SET<br>CK_Post_set can not be 0,after the falling edge of entx,keep it for (CK_POST_SET + 2)* Tclk and then turn off the clk. |
| 23:16         | R/W        | 0x0         | CK_PRE_SET<br>Clk pre = ( ( CK_PRE_SET + 2)+( 0 ~ LPX_TM_SET ) )* Tclk                                                                |
| 15:8          | R/W        | 0x0         | CK_ZERO_SET<br>CK_Zero_set can not be 0,when entxc is set 1, after (CK_ZERO_SET + 2 )* Tclk, the enckq will be set as 1.              |
| 7:0           | R/W        | 0x0         | CK_PREP_SET<br>Clk prepare = ( CK_PREP_SET + 3 ) * clk                                                                                |

#### 6.2.6.58. 0x1018 DPHY TX Timing Parameter 2 Register(Default Value: 0x0000\_0000)

| Offset:0x1018 |            |             | Register Name: DPHY_TX_TIME2_REG                                                                                                                                                                                                                        |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                             |
| 31:29         | /          | /           | /                                                                                                                                                                                                                                                       |
| 28            | R/W        | 0x0         | HS_DLY_MODE<br>The setting of HS zero time depending on HS_DLYMODE:<br>when HS_DLYMODE=0, HS_ZERO_TIME > 20*Tbyteclk<br><br>When HS_DLYMODE=1,HS_ZERO_TIME = (HS_DLY_SET + 4 )*Tclk - 2*(LPX_TM_SET + 1)*Tclk + (2~23)*Tbyteclk - (HS_PRE_SET + 4)*Tclk |
| 27:24         | /          | /           | /                                                                                                                                                                                                                                                       |
| 23:8          | R/W        | 0x0         | HS_DLY_SET                                                                                                                                                                                                                                              |

|     |     |     |                                                                                           |
|-----|-----|-----|-------------------------------------------------------------------------------------------|
|     |     |     | Use this value to prolong the time before LP switch to HS,cut down the length of HS-Zero. |
| 7:0 | R/W | 0x0 | CK_TRAIL_SET<br>CK_TRAIL_SET clk tail =( CK_TRAIL_SET + 2 )* Tclk                         |

#### 6.2.6.59. 0x101C DPHY TX Timing Parameter 3 Register(Default Value: 0x0000\_0000)

| Offset:0x101C |            |             | Register Name: DPHY_TX_TIME3_REG        |
|---------------|------------|-------------|-----------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                             |
| 31:20         | /          | /           | /                                       |
| 19:0          | R/W        | 0x0         | LPTX_ULPS_EXIT_SET<br>ULPS exit Cycles. |

#### 6.2.6.60. 0x1030 DPHY RX Timing Parameter 0 Register(Default Value: 0x0000\_0000)

| Offset:0x1030 |            |             | Register Name: DPHY_RX_TIME0_REG                                                                                                                                |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:24         | R/W        | 0x0         | HSRX_SYNC_ERR_TO<br>When HS SOT is not detected until reaching the hs sync error timeout counter, the SOT_ERR should be flagged. Only valid for data lane.      |
| 23:16         | R/W        | 0x0         | HSRX_CLK_MISS<br>When clock lane is detected no clock until hs rx clock miss counter, the receiver disconnect the terminal register. Only valid for clock lane. |
| 15:8          | R/W        | 0x0         | LPRX_TO<br>The timeout counter for receiver in LP mode.                                                                                                         |
| 7:6           | /          | /           | /                                                                                                                                                               |
| 5             | R/W        | 0x0         | HSRX_SYNC_ERR_TO_EN<br>0: Disable<br>1: Enable HSRX_SYNC_ERR_TO counter                                                                                         |
| 4             | R/W        | 0x0         | HSRX_CLK_MISS_EN<br>0: Disable<br>1: Enable HSRX_CLK_MISS counter                                                                                               |
| 3:2           | /          | /           | /                                                                                                                                                               |
| 1             | R/W        | 0x0         | FREQ_CNT_EN<br>0:Disable<br>1:Enable<br>When enabled, the FREQ_CNT counter is counted by DPhy Clock between 1000 Byte Clock.                                    |
| 0             | R/W        | 0x0         | LPRX_TO_EN<br>LP RX timeout enable<br>0: Disable<br>1: Enable                                                                                                   |

#### 6.2.6.61. 0x1034 DPHY RX Timing Parameter 1 Register(Default Value: 0x0000\_0000)

| Offset:0x1034 |            |             | Register Name: DPHY_RX_TIME1_REG                                                                                                                                                                   |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:20         | R/W        | 0x0         | RX_DLY<br>The time that DPhy process hs fifo data and pull off data valid signal to protocol after DPhy has detected the lane state from HS to LP. It should be more than 8 byte clock cycle time. |
| 19:0          | R/W        | 0x0         | LPRX_ULPS_WP<br>When receivers detects MARK-I for ULPS Wakeup Cycles, the corresponding ULPS WP is pending. (Valid for clock lane and all data lane).                                              |

#### 6.2.6.62. 0x1040 DPHY RX Timing Parameter 3 Register(Default Value: 0x0000\_0000)

| Offset:0x1040 |            |             | Register Name: DPHY_RX_TIME3_REG                                                                     |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                          |
| 31:16         | R/W        | 0x0         | LPRST_DLY<br>The added delayed time that reset the hs-fifo after the DPhy has detected the HS-to-LP. |
| 15:0          | R          | 0x0         | FREQ_CNT<br>The value of FREQ_CNT counter is counted by DPhy Clock between 1000 Byte Cock.           |

#### 6.2.6.63. 0x104C DPHY Analog 0 Register(Default Value: 0x0000\_0044)

| Offset:0x104C |            |             | Register Name: DPHY_ANA0_REG                            |
|---------------|------------|-------------|---------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                             |
| 31:24         | /          | /           | /                                                       |
| 23:20         | R/W        | 0x0         | dsi_reg_preemph0<br>Data lane0 hstx preemphasis tuning. |
| 19:16         | R/W        | 0x0         | dsi_reg_preemph1<br>Data lane1 hstx preemphasis tuning. |
| 15:12         | R/W        | 0x0         | dsi_reg_preemph2<br>Data lane2 hstx preemphasis tuning. |
| 11:8          | R/W        | 0x0         | dsi_reg_preemph3<br>Data lane3 hstx preemphasis tuning. |
| 7             | /          | /           | /                                                       |
| 6:4           | R/W        | 0x4         | dsi_reg_lptx_setc<br>Lptx current bias tuning.          |

|     |     |     |                                                     |
|-----|-----|-----|-----------------------------------------------------|
| 3   | /   | /   | /                                                   |
| 2:0 | R/W | 0x4 | dsi_reg_lptx_setr<br>Lptx output resistance tuning. |

#### 6.2.6.64. 0x1050 DPHY Analog 1 Register(Default Value: 0x0000\_0000)

| Offset:0x1050 |            |             | Register Name: DPHY_ANA0_REG                                            |
|---------------|------------|-------------|-------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                             |
| 31            | R/W        | 0x0         | envtt_mode<br>Hstx vtt enable.                                          |
| 30:27         | /          | /           | /                                                                       |
| 26            | R/W        | 0x0         | dsi_en_phback_lock<br>Back sync clk lock enable.                        |
| 25            | R/W        | 0x0         | dsi_en_phback_sync<br>Back sync clk enable.                             |
| 24            | R/W        | 0x0         | dsi_en_soft_phsel<br>Resister control enable for phase back clk.        |
| 23:22         | R/W        | 0x0         | dsi_reg_soft_phsel<br>Resister tuning for phase back clk.               |
| 21:20         | R/W        | 0x0         | dsi_reg_phsync_set<br>Set to digital clock phase for parallel data.     |
| 19:16         | R/W        | 0x0         | dsi_en_clkpatd<br>Hstx clk pattern enable for data lane0 to lane3.      |
| 15            | /          | /           | /                                                                       |
| 14:11         | R/W        | 0x0         | dsi_en_vtt_test<br>Hstx vtt test enable for data lane0 to lane3.        |
| 10            | R/W        | 0x0         | dsi_en_vtt_testc<br>Hstx vtt test enable for clk lane.                  |
| 9:6           | R/W        | 0x0         | dsi_reg_hstx_plr<br>Data lane0 to lane3 polar reverse.                  |
| 5             | R/W        | 0x0         | dsi_reg_hstxck_plr<br>Clk lane polar reverse.                           |
| 4:1           | R/W        | 0x0         | dsi_en_vlptx_test<br>Data lane0 to lane3 Lptx analog point test enable. |
| 0             | R/W        | 0x0         | dsi_en_vlptx_testc<br>Clk lane Lptx analog point test enable.           |

#### 6.2.6.65. 0x1054 DPHY Analog 2 Register(Default Value: 0x0100\_0F20)

| Offset:0x1054 |            |             | Register Name: DPHY_ANA2_REG |
|---------------|------------|-------------|------------------------------|
| Bit           | Read/Write | Default/Hex | Description                  |
| 31:28         | /          | /           | /                            |

|       |     |     |                                                                                                         |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------|
| 27:24 | R/W | 0x1 | EN_P2S<br>Enable signal for HS p2s module in Data Lane<3:0>                                             |
| 23:12 | /   | /   | /                                                                                                       |
| 11:8  | R/W | 0xF | EN_TXTERM<br>Enable signal for HStx termination in Data Lane<3:0>                                       |
| 7:6   | /   | /   | /                                                                                                       |
| 5     | R/W | 0x1 | EN_TXTREMC<br>Enable signal for HStx termination in Clock Lane                                          |
| 4     | R/W | 0x0 | EN_CLK<br>Enable signal for ref clock is active to MIPI. It can not be controlled by CPU.<br>Set as "1" |
| 3:2   | /   | /   | /                                                                                                       |
| 1     | R/W | 0x0 | EN_IREF<br>Enable signal for current bias is active<br>Set as "1"                                       |
| 0     | R/W | 0x0 | ANA_CPU_EN<br>Enable all register with cpu, when disable, those bits are control by circuit automatic   |

#### 6.2.6.66. 0x1058 DPHY Analog 3 Register(Default Value: 0xF800\_0000)

| Offset:0x1058 |            |             | Register Name: DPHY_ANA3_REG                                                             |
|---------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                              |
| 31:28         | R/W        | 0xF         | EN_VDRVLDON<br>Enable Signal for HS TX LDO in Data Lane<3:0><br>Set as "1111" when hstx  |
| 27            | R/W        | 0x1         | EN_VDRVLDONC<br>Enable Signal for HS TX LDO in Clock Lane<br>Set as "1" when hstx        |
| 26            | R/W        | 0x0         | EN_DIV2<br>Enable Signal for input clock divided by 2.<br>Set as "1"                     |
| 25            | R/W        | 0x0         | EN_LVCK<br>Enable Signal for clock power LDO is active<br>DSI set as "1"; CSI set as "0" |
| 24            | R/W        | 0x0         | EN_LV<br>Enable Signal for data power LDO is active<br>Set as "1"                        |
| 23            | R/W        | 0x0         | EN_ULPSC<br>Data Lane<3:0> LP contention detect threshold tuning.                        |
| 22:19         | R/W        | 0x0         | EN_ULPS<br>CLK Lane LP contention detect threshold tuning.                               |

|       |     |     |                                                                          |
|-------|-----|-----|--------------------------------------------------------------------------|
| 18    | R/W | 0x0 | EN_VREF<br>Enable signal for reference power LDO is active<br>Set as "1" |
| 17:15 | /   | /   | /                                                                        |
| 14    | R/W | 0x0 | EN_LPCDC<br>Enable signal for LP cd module is active in Clock Lane       |
| 13    | R/W | 0x0 | EN_LPTXC<br>Enable signal for LP tx module is active in Clock Lane       |
| 12    | R/W | 0x0 | EN_LPRXC<br>Enable signal for LP rx module is active in Clock Lane       |
| 11:8  | R/W | 0x0 | EN_LPCD<br>Enable signal for LP cd module is active in Data Lane<3:0>    |
| 7:4   | R/W | 0x0 | EN_LPRX<br>Enable signal for LP rx module is active in Data Lane<3:0>    |
| 3:0   | R/W | 0x0 | EN_LPTX<br>Enable signal for LP tx module is active in Data Lane<3:0>    |

#### 6.2.6.67. 0x105C DPHY Analog 4 Register(Default Value: 0x0000\_0000)

| Offset:0x105C |            |             | Register Name: DPHY_ANA4_REG                                  |
|---------------|------------|-------------|---------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                   |
| 31            | R/W        | 0x0         | dsi_en_mipi<br>Mipi dsi enable.                               |
| 30            | R/W        | 0x0         | dsi_en_comtest<br>Common test enable.                         |
| 29:28         | R/W        | 0x0         | dsi_reg_comtest<br>Common test select.                        |
| 27            | /          | /           | /                                                             |
| 26:24         | R/W        | 0x0         | dsi_reg_ib<br>Input bias current tuning.                      |
| 23            | /          | /           | /                                                             |
| 22:20         | R/W        | 0x0         | dsi_reg_vres_set<br>Res calibration reference voltage tuning. |
| 19            | /          | /           | /                                                             |
| 18:16         | R/W        | 0x0         | dsi_reg_vtt_set<br>Hstx reference voltage tuning.             |
| 15            | /          | /           | /                                                             |
| 14:12         | R/W        | 0x0         | dsi_reg_vlptx_set<br>LPtX reference voltage tuning.           |
| 11            | /          | /           | /                                                             |
| 10:8          | R/W        | 0x0         | dsi_reg_vlv_set<br>LDO voltage tuning for core power.         |
| 7             | R/W        | 0x0         | dsi_en_rescal                                                 |

|     |     |     |                                                              |
|-----|-----|-----|--------------------------------------------------------------|
|     |     |     | Resistance calibration enable.                               |
| 6   | R/W | 0x0 | dsi_on_rescal<br>Resistance calibration on.                  |
| 5   | R/W | 0x0 | dsi_en_soft_rcal<br>Software Resistance calibration enable.  |
| 4:0 | R/W | 0x0 | dsi_reg_soft_rcal<br>Software Resistance calibration tuning. |

#### 6.2.6.68. 0x1060 DPHY Interrupt Enable 0 Register(Default Value: 0x0000\_0000)

| Offset:0x1060 |            |             | Register Name: DPHY_INT_EN0_REG                                                                                      |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                          |
| 31            | R/W        | 0x0         | CD_LP1_ERR_D3_INT<br>Contention Detection detects LP1 error interrupt                                                |
| 30            | R/W        | 0x0         | CD_LP0_ERR_D3_INT<br>Contention Detection detects LP0 error interrupt                                                |
| 29            | R/W        | 0x0         | CD_LP1_ERR_D2_INT<br>Contention Detection detects LP1 error interrupt                                                |
| 28            | R/W        | 0x0         | CD_LP0_ERR_D2_INT<br>Contention Detection detects LP0 error interrupt                                                |
| 27            | R/W        | 0x0         | CD_LP1_ERR_D1_INT<br>Contention Detection detects LP1 error interrupt                                                |
| 26            | R/W        | 0x0         | CD_LP0_ERR_D1_INT<br>Contention Detection detects LP0 error interrupt                                                |
| 25            | R/W        | 0x0         | CD_LP1_ERR_D0_INT<br>Contention Detection detects LP1 error interrupt                                                |
| 24            | R/W        | 0x0         | CD_LP0_ERR_D0_INT<br>Contention Detection detects LP0 error interrupt                                                |
| 23            | R/W        | 0x0         | CD_LP1_ERR_CLK_INT<br>Contention Detection detects LP1 error interrupt                                               |
| 22            | R/W        | 0x0         | CD_LP0_ERR_CLK_INT<br>Contention Detection detects LP0 error interrupt                                               |
| 21:16         | /          | /           | /                                                                                                                    |
| 15            | R/W        | 0x0         | RX_ALG_ERR_D3_INT<br>The payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN |
| 14            | R/W        | 0x0         | RX_ALG_ERR_D2_INT<br>The payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN |
| 13            | R/W        | 0x0         | RX_ALG_ERR_D1_INT<br>The payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN |
| 12            | R/W        | 0x0         | RX_ALG_ERR_D0_INT                                                                                                    |

|    |     |     |                                                                                                  |
|----|-----|-----|--------------------------------------------------------------------------------------------------|
|    |     |     | The payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN. |
| 11 | R/W | 0x0 | SOT_SYNC_ERR_D3_INT<br>DPHY RX can not detected SOT sequence at Data Lane 0 interrupt.           |
| 10 | R/W | 0x0 | SOT_SYNC_ERR_D2_INT<br>DPHY RX can not detected SOT sequence at Data Lane 0 interrupt.           |
| 9  | R/W | 0x0 | SOT_SYNC_ERR_D1_INT<br>DPHY RX can not detected SOT sequence at Data Lane 0 interrupt.           |
| 8  | R/W | 0x0 | SOT_SYNC_ERR_D0_INT<br>DPHY RX can not detected SOT sequence at Data Lane 0 interrupt.           |
| 7  | R/W | 0x0 | SOT_ERR_D3_INT<br>DPHY RX detected SOT sequence with 1-bit error at Data Lane 0 interrupt.       |
| 6  | R/W | 0x0 | SOT_ERR_D2_INT<br>DPHY RX detected SOT sequence with 1-bit error at Data Lane 0 interrupt.       |
| 5  | R/W | 0x0 | SOT_ERR_D1_INT<br>DPHY RX detected SOT sequence with 1-bit error at Data Lane 0 interrupt.       |
| 4  | R/W | 0x0 | SOT_ERR_D0_INT<br>DPHY RX detected SOT sequence with 1-bit error at Data Lane 0 interrupt.       |
| 3  | R/W | 0x0 | SOT_D3_INT<br>0: Disable<br>1: Enable<br>DPHY RX detected SOT sequence at Data Lane 3 interrupt. |
| 2  | R/W | 0x0 | SOT_D2_INT<br>0: Disable<br>1: Enable<br>DPHY RX detected SOT sequence at Data Lane 2 interrupt. |
| 1  | R/W | 0x0 | SOT_D1_INT<br>0: Disable<br>1: Enable<br>DPHY RX detected SOT sequence at Data Lane 1 interrupt. |
| 0  | R/W | 0x0 | SOT_D0_INT<br>0: Disable<br>1: Enable<br>DPHY RX detected SOT sequence at Data Lane 0 interrupt. |

#### 6.2.6.69. 0x1064 DPHY Interrupt Enable 1 Register(Default Value: 0x0000\_0000)

| Offset:0x1064 |            | Register Name: DPHY_INT_EN1_REG |             |
|---------------|------------|---------------------------------|-------------|
| Bit           | Read/Write | Default/Hex                     | Description |

|    |     |     |                                                                                                             |
|----|-----|-----|-------------------------------------------------------------------------------------------------------------|
| 31 | R/W | 0x0 | FALSE_CTL_D3_INT<br>A false control occurs at Data Lane 3 interrupt.                                        |
| 30 | R/W | 0x0 | FALSE_CTL_D2_INT<br>A false control occurs at Data Lane 2 interrupt.                                        |
| 29 | R/W | 0x0 | FALSE_CTL_D1_INT<br>A false control occurs at Data Lane 1 interrupt.                                        |
| 28 | R/W | 0x0 | FALSE_CTL_D0_INT<br>A false control occurs at Data Lane 0 interrupt.                                        |
| 27 | R/W | 0x0 | ESC_CMD_ERR_D3_INT<br>DPHY RX received can not recognize the Escape Entry Command at Data Lane 3 interrupt. |
| 26 | R/W | 0x0 | ESC_CMD_ERR_D2_INT<br>DPHY RX received can not recognize the Escape Entry Command at Data Lane 2 interrupt. |
| 25 | R/W | 0x0 | ESC_CMD_ERR_D1_INT<br>DPHY RX received can not recognize the Escape Entry Command at Data Lane 1 interrupt. |
| 24 | R/W | 0x0 | ESC_CMD_ERR_D0_INT<br>DPHY RX received can not recognize the Escape Entry Command at Data Lane 0 interrupt. |
| 23 | R/W | 0x0 | RST_D3_INT<br>DPHY RX detected Reset Trigger sequence at Data Lane 3 interrupt.                             |
| 22 | R/W | 0x0 | RST_D2_INT<br>DPHY RX detected Reset Trigger sequence at Data Lane 2 interrupt.                             |
| 21 | R/W | 0x0 | RST_D1_INT<br>DPHY RX detected Reset Trigger sequence at Data Lane 1 interrupt.                             |
| 20 | R/W | 0x0 | RST_D0_INT<br>DPHY RX detected Reset Trigger sequence at Data Lane 0 interrupt.                             |
| 19 | R/W | 0x0 | UNDEF5_D0_INT<br>DPHY RX received undefined 5 sequence at Data Lane 0 interrupt.                            |
| 18 | R/W | 0x0 | UNDEF4_D0_INT<br>DPHY RX received undefined 4 sequence at Data Lane 0 interrupt.                            |
| 17 | R/W | 0x0 | UNDEF3_D0_INT<br>DPHY RX received undefined 3 sequence at Data Lane 0 interrupt.                            |
| 16 | R/W | 0x0 | UNDEF2_D0_INT<br>DPHY RX received undefined 2 sequence at Data Lane 0 interrupt.                            |
| 15 | R/W | 0x0 | UNDEF1_D0_INT<br>DPHY RX received undefined 1 sequence at Data Lane 0 interrupt.                            |
| 14 | R/W | 0x0 | TX_TRND_ERR_D0_INT<br>DPHY TX turn around error at Data Lane 0 interrupt.                                   |
| 13 | R/W | 0x0 | RX_TRND_D0_INT<br>DPHY RX received turn around sequence at Data Lane 0 interrupt.                           |
| 12 | R/W | 0x0 | LPDT_D0_INT<br>DPHY RX complete LPDT transfer at Data Lane 0 interrupt.                                     |

|       |     |     |                                                                          |
|-------|-----|-----|--------------------------------------------------------------------------|
| 11:10 | /   | /   | /                                                                        |
| 9     | R/W | 0x0 | ULPS_WP_CLK_INT<br>DPHY RX detected ULPS wakeup at Clock Lane interrupt. |
| 8     | R/W | 0x0 | ULPS_CLK_INT<br>DPHY RX detected ULPS sequence at Clock Lane interrupt.  |
| 7     | R/W | 0x0 | ULPS_WP_D3_INT<br>DPHY RX detected ULPS wakeup at Data Lane 3 interrupt. |
| 6     | R/W | 0x0 | ULPS_WP_D2_INT<br>DPHY RX detected ULPS wakeup at Data Lane 2 interrupt. |
| 5     | R/W | 0x0 | ULPS_WP_D1_INT<br>DPHY RX detected ULPS wakeup at Data Lane 1 interrupt. |
| 4     | R/W | 0x0 | ULPS_WP_D0_INT<br>DPHY RX detected ULPS wakeup at Data Lane 0 interrupt. |
| 3     | R/W | 0x0 | ULPS_D3_INT<br>DPHY RX detected ULPS sequence at Data Lane 3 interrupt.  |
| 2     | R/W | 0x0 | ULPS_D2_INT<br>DPHY RX detected ULPS sequence at Data Lane 2 interrupt.  |
| 1     | R/W | 0x0 | ULPS_D1_INT<br>DPHY RX detected ULPS sequence at Data Lane 1 interrupt.  |
| 0     | R/W | 0x0 | ULPS_D0_INT<br>DPHY RX detected ULPS sequence at Data Lane 0 interrupt.  |

#### 6.2.6.70. 0x1070 DPHY Interrupt Pending 0 Register(Default Value: 0x0000\_0000)

| Offset:0x1070 |            |             | Register Name: DPHY_INT_PDO_REG                                                                   |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                       |
| 31            | R/W        | 0x0         | CD_LP1_ERR_D3_PD<br>Contention Detection detects LP1 error interrupt pending. Write "1" to clear. |
| 30            | R/W        | 0x0         | CD_LP0_ERR_D3_PD<br>Contention Detection detects LP0 error interrupt pending. Write "1" to clear. |
| 29            | R/W        | 0x0         | CD_LP1_ERR_D2_PD<br>Contention Detection detects LP1 error interrupt pending. Write "1" to clear. |
| 28            | R/W        | 0x0         | CD_LP0_ERR_D2_PD<br>Contention Detection detects LP0 error interrupt pending. Write "1" to clear. |
| 27            | R/W        | 0x0         | CD_LP1_ERR_D0_PD<br>Contention Detection detects LP1 error interrupt pending. Write "1" to clear. |
| 26            | R/W        | 0x0         | CD_LP0_ERR_D0_PD<br>Contention Detection detects LP0 error interrupt pending. Write "1" to        |

|       |     |     |                                                                                                                                                                                                               |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | clear.                                                                                                                                                                                                        |
| 25    | R/W | 0x0 | CD_LP1_ERR_D1_PD<br>Contention Detection detects LP1 error interrupt pending. Write "1" to clear.                                                                                                             |
| 24    | R/W | 0x0 | CD_LP0_ERR_D1_PD<br>Contention Detection detects LP0 error interrupt pending. Write "1" to clear.                                                                                                             |
| 23    | R/W | 0x0 | CD_LP1_ERR_CLK_PD<br>Contention Detection detects LP1 error interrupt pending. Write "1" to clear.                                                                                                            |
| 22    | R/W | 0x0 | CD_LP0_ERR_CLK_PD<br>Contention Detection detects LP0 error interrupt pending. Write "1" to clear.                                                                                                            |
| 21:16 | /   | /   | /                                                                                                                                                                                                             |
| 15    | R/W | 0x0 | RX_ALG_ERR_D3_PD<br>Asserted if the payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN.                                                                              |
| 14    | R/W | 0x0 | RX_ALG_ERR_D2_PD<br>Asserted if the payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN.                                                                              |
| 13    | R/W | 0x0 | RX_ALG_ERR_D1_PD<br>Asserted if the payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN.                                                                              |
| 12    | R/W | 0x0 | RX_ALG_ERR_D0_PD<br>Asserted if the payload that DPHY RX received is not aligned to 8bit or 9bit, which depends on HSRX_8B9B_EN.                                                                              |
| 11    | R/W | 0x0 | SOT_SYNC_ERR_D3_PD<br>Asserted if DPHY RX cant not detected SOT sequence at Data Lane 3.<br>The SoT Leader sequence is corrupted in a way that proper synchronization cannot be expected. Write "1" to clear. |
| 10    | R/W | 0x0 | SOT_SYNC_ERR_D2_PD<br>Asserted if DPHY RX cant not detected SOT sequence at Data Lane 2.<br>The SoT Leader sequence is corrupted in a way that proper synchronization cannot be expected. Write "1" to clear. |
| 9     | R/W | 0x0 | SOT_SYNC_ERR_D1_PD<br>Asserted if DPHY RX cant not detected SOT sequence at Data Lane 1.<br>The SoT Leader sequence is corrupted in a way that proper synchronization cannot be expected. Write "1" to clear. |
| 8     | R/W | 0x0 | SOT_SYNC_ERR_D0_PD<br>Asserted if DPHY RX cant not detected SOT sequence at Data Lane 0.<br>The SoT Leader sequence is corrupted in a way that proper synchronization cannot be expected. Write "1" to clear. |
| 7     | R/W | 0x0 | SOT_ERR_D3_PD<br>Asserted if DPHY RX detected SOT sequence with 1-bit error at Data Lane 3. The confidence in the payload data is lower. Write "1" to clear.                                                  |

|   |     |     |                                                                                                                                                              |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | R/W | 0x0 | SOT_ERR_D2_PD<br>Asserted if DPHY RX detected SOT sequence with 1-bit error at Data Lane 2. The confidence in the payload data is lower. Write "1" to clear. |
| 5 | R/W | 0x0 | SOT_ERR_D1_PD<br>Asserted if DPHY RX detected SOT sequence with 1-bit error at Data Lane 1. The confidence in the payload data is lower. Write "1" to clear. |
| 4 | R/W | 0x0 | SOT_ERR_D0_PD<br>Asserted if DPHY RX detected SOT sequence with 1-bit error at Data Lane 0. The confidence in the payload data is lower. Write "1" to clear. |
| 3 | R/W | 0x0 | SOT_D3_PD<br>Asserted if DPHY RX detected SOT sequence at Data Lane 3. Write "1" to clear.                                                                   |
| 2 | R/W | 0x0 | SOT_D2_PD<br>Asserted if DPHY RX detected SOT sequence at Data Lane 2. Write "1" to clear.                                                                   |
| 1 | R/W | 0x0 | SOT_D1_PD<br>Asserted if DPHY RX detected SOT sequence at Data Lane 1. Write "1" to clear.                                                                   |
| 0 | R/W | 0x0 | SOT_D0_PD<br>Asserted if DPHY RX detected SOT sequence at Data Lane 0. Write "1" to clear.                                                                   |

#### 6.2.6.71. 0x1074 DPHY Interrupt Pending 1 Register(Default Value: 0x0000\_0000)

| Offset:0x1074 |            |             | Register Name: DPHY_INT_PD1_REG                                                                                                                                                                            |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                |
| 31            | R/W        | 0x0         | FALSE_CTL_D3_PD<br>Asserted if a LP-Rqst (LP-10) is not followed by the remainder of a valid Escape sequence or a HS-Rqst (LP-01) is not correctly followed by a Bridge State (LP-00). Write "1" to clear. |
| 30            | R/W        | 0x0         | FALSE_CTL_D2_PD<br>Asserted if a LP-Rqst (LP-10) is not followed by the remainder of a valid Escape sequence or a HS-Rqst (LP-01) is not correctly followed by a Bridge State (LP-00). Write "1" to clear. |
| 29            | R/W        | 0x0         | FALSE_CTL_D1_PD<br>Asserted if a LP-Rqst (LP-10) is not followed by the remainder of a valid Escape sequence or a HS-Rqst (LP-01) is not correctly followed by a Bridge State (LP-00). Write "1" to clear. |
| 28            | R/W        | 0x0         | FALSE_CTL_D0_PD<br>Asserted if a LP-Rqst (LP-10) is not followed by the remainder of a valid Escape sequence or a HS-Rqst (LP-01) is not correctly followed by a Bridge State (LP-00). Write "1" to clear. |
| 27            | R/W        | 0x0         | ESC_CMD_ERR_D3_PD<br>Asserted if DPHY RX received can not recognize the Escape Entry                                                                                                                       |

|    |     |     |                                                                                                                                  |
|----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | Command at Data Lane 3. Write "1" to clear.                                                                                      |
| 26 | R/W | 0x0 | ESC_CMD_ERR_D2_PD<br>Asserted if DPHY RX received can not recognize the Escape Entry Command at Data Lane 2. Write "1" to clear. |
| 25 | R/W | 0x0 | ESC_CMD_ERR_D1_PD<br>Asserted if DPHY RX received can not recognize the Escape Entry Command at Data Lane 1. Write "1" to clear. |
| 24 | R/W | 0x0 | ESC_CMD_ERR_D0_PD<br>Asserted if DPHY RX received can not recognize the Escape Entry Command at Data Lane 0. Write "1" to clear. |
| 23 | R/W | 0x0 | RST_D3_PD<br>Asserted if DPHY RX detected Reset Trigger sequence at Data Lane 3. Write "1" to clear.                             |
| 22 | R/W | 0x0 | RST_D2_PD<br>Asserted if DPHY RX detected Reset Trigger sequence at Data Lane 2. Write "1" to clear.                             |
| 21 | R/W | 0x0 | RST_D1_PD<br>Asserted if DPHY RX detected Reset Trigger sequence at Data Lane 1. Write "1" to clear.                             |
| 20 | R/W | 0x0 | RST_D0_PD<br>Asserted if DPHY RX detected Reset Trigger sequence at Data Lane 0. Write "1" to clear.                             |
| 19 | R/W | 0x0 | UNDEF5_D0_PD<br>Asserted if DPHY RX received undefined 5 sequence at Data Lane 0. Write "1" to clear.<br>"10100000"              |
| 18 | R/W | 0x0 | UNDEF4_D0_PD<br>Asserted if DPHY RX received undefined 4 sequence at Data Lane 0. Write "1" to clear.<br>"00100001"              |
| 17 | R/W | 0x0 | UNDEF3_D0_PD<br>Asserted if DPHY RX received undefined 3 sequence at Data Lane 0. Write "1" to clear.<br>"01011101"              |
| 16 | R/W | 0x0 | UNDEF2_D0_PD<br>Asserted if DPHY RX received undefined 2 sequence at Data Lane 0. Write "1" to clear.<br>"11011110"              |
| 15 | R/W | 0x0 | UNDEF1_D0_PD<br>Asserted if DPHY RX received undefined 1 sequence at Data Lane 0. Write "1" to clear.<br>"10011111"              |
| 14 | R/W | 0x0 | TX_TRND_ERR_D0_PD<br>Asserted if DPHY TX turn around error at Data Lane 0. Write "1" to clear.                                   |

|       |     |     |                                                                                                            |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------|
| 13    | R/W | 0x0 | RX_TRND_D0_PD<br>Asserted if DPHY RX received turn around sequence at Data Lane 0. Write "1" to clear.     |
| 12    | R/W | 0x0 | LPDT_D0_PD<br>Asserted if DPHY RX complete LPDT transfer at Data Lane 0 .Write "1" to clear.<br>"11100001" |
| 11:10 | /   | /   | /                                                                                                          |
| 9     | R/W | 0x0 | ULPS_WP_CLK_PD<br>Asserted if DPHY RX detected ULPS wakeup at Clock Lane. Write "1" to clear.              |
| 8     | R/W | 0x0 | ULPS_CLK_PD<br>Asserted if DPHY RX detected ULPS sequence at Clock Lane. Write "1" to clear.               |
| 7     | R/W | 0x0 | ULPS_WP_D3_PD<br>Asserted if DPHY RX detected ULPS wakeup at Data Lane 3. Write "1" to clear.              |
| 6     | R/W | 0x0 | ULPS_WP_D2_PD<br>Asserted if DPHY RX detected ULPS wakeup at Data Lane 2. Write "1" to clear.              |
| 5     | R/W | 0x0 | ULPS_WP_D1_PD<br>Asserted if DPHY RX detected ULPS wakeup at Data Lane 1. Write "1" to clear.              |
| 4     | R/W | 0x0 | ULPS_WP_D0_PD<br>Asserted if DPHY RX detected ULPS wakeup at Data Lane 0. Write "1" to clear.              |
| 3     | R/W | 0x0 | ULPS_D3_PD<br>Asserted if DPHY RX detected ULPS sequence at Data Lane 3. Write "1" to clear.               |
| 2     | R/W | 0x0 | ULPS_D2_PD<br>Asserted if DPHY RX detected ULPS sequence at Data Lane 2. Write "1" to clear.               |
| 1     | R/W | 0x0 | ULPS_D1_PD<br>Asserted if DPHY RX detected ULPS sequence at Data Lane 1. Write "1" to clear.               |
| 0     | R/W | 0x0 | ULPS_D0_PD<br>Asserted if DPHY RX detected ULPS sequence at Data Lane 0. Write "1" to clear.<br>"00011110" |

#### 6.2.6.72. 0x10E0 DPHY Debug 0 Register(Default Value: 0x0000\_0000)

|                |                              |
|----------------|------------------------------|
| Offset: 0x10E0 | Register Name: DPHY_DBG0_REG |
|----------------|------------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                     |
|------------|-------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 31:29      | /                 | /                  | /                                                                                                                                      |
| 28         | R                 | 0x0                | DIRECTION<br>0:No lane switch into HS transmission<br>1:At least one lane switch into HS transmission                                  |
| 27:26      | /                 | /                  | /                                                                                                                                      |
| 25         | R                 | 0x0                | Soft_rcal_cmpo<br>Resistance calibration comparator output.                                                                            |
| 24         | R                 | 0x0                | Soft_rcal_flag<br>Resistance calibration completion flag.                                                                              |
| 23:19      | R                 | 0x0                | Soft_rcal_value<br>Resistance calibration bit return to system.                                                                        |
| 18:16      | R                 | 0x0                | LPTX_STA_CLK<br>000: STP_ST<br>001: HSRQ_ST<br>010: ESRQ_ST<br>011: TNRD_ST<br>100: ULPS_ST<br>101: HS_ST<br>110: ESP_ST<br>111: RX_ST |
| 15         | /                 | /                  | /                                                                                                                                      |
| 14:12      | R                 | 0x0                | LPTX_STA_D3<br>000: STP_ST<br>001: HSRQ_ST<br>010: ESRQ_ST<br>011: TNRD_ST<br>100: ULPS_ST<br>101: HS_ST<br>110: ESP_ST<br>111: RX_ST  |
| 11         | /                 | /                  | /                                                                                                                                      |
| 10:8       | R                 | 0x0                | LPTX_STA_D2<br>000: STP_ST<br>001: HSRQ_ST<br>010: ESRQ_ST<br>011: TNRD_ST<br>100: ULPS_ST<br>101: HS_ST<br>110: ESP_ST<br>111: RX_ST  |
| 7          | /                 | /                  | /                                                                                                                                      |
| 6:4        | R                 | 0x0                | LPTX_STA_D1<br>000: STP_ST<br>001: HSRQ_ST                                                                                             |

|     |   |     |                                                                                                                                       |
|-----|---|-----|---------------------------------------------------------------------------------------------------------------------------------------|
|     |   |     | 010: ESRQ_ST<br>011: TNRD_ST<br>100: ULPS_ST<br>101: HS_ST<br>110: ESP_ST<br>111: RX_ST                                               |
| 3   | / | /   | /                                                                                                                                     |
| 2:0 | R | 0x0 | LPTX_STA_D0<br>000: STP_ST<br>001: HSRQ_ST<br>010: ESRQ_ST<br>011: TNRD_ST<br>100: ULPS_ST<br>101: HS_ST<br>110: ESP_ST<br>111: RX_ST |

#### 6.2.6.73. 0x10E4 DPHY Debug 1 Register(Default Value: 0x0000\_0000)

| Offset: 0x10E4 |            |             | Register Name: DPHY_DBG1_REG                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:14          | /          | /           | /                                                                                           |
| 13:12          | R/W        | 0x0         | LPTX_SET_CK<br>Clock Lane output state<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 11:10          | R/W        | 0x0         | LPTX_SET_D3<br>Data Lane 3 output state<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11 |
| 9:8            | R/W        | 0x0         | LPTX_SET_D2<br>Data Lane 2 output state<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11 |
| 7:6            | R/W        | 0x0         | LPTX_SET_D1<br>Data Lane 1 output state<br>00: LP-00<br>01: LP-01                           |

|     |     |     |                                                                                             |
|-----|-----|-----|---------------------------------------------------------------------------------------------|
|     |     |     | 10: LP-10<br>11: LP-11                                                                      |
| 5:4 | R/W | 0x0 | LPTX_SET_D0<br>Data Lane 0 output state<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11 |
| 3:2 | /   | /   | /                                                                                           |
| 1   | R/W | 0x0 | HSTX_DBG_EN<br>0: normal mode<br>1: debug mode                                              |
| 0   | R/W | 0x0 | LPTX_DBG_EN<br>0: normal mode<br>1: debug mode                                              |

#### 6.2.6.74. 0x10E8 DPHY Debug 2 Register(Default Value: 0x0000\_0000)

| Offset: 0x10E8 |            |             | Register Name: DPHY_DBG2_REG                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:0           | R/W        | 0x0         | HSTX_Data<br>Bit31-24: D3_DATA<br>Bit23-16: D2_DATA<br>Bit15-08: D1_DATA<br>Bit07-00: D0_DATA |

#### 6.2.6.75. 0x10EC DPHY Debug 3 Register(Default Value: 0x0000\_0000)

| Offset:0x10EC |            |             | Register Name: DPHY_DBG3_REG                                                                                                                                                     |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:20         | /          | /           | /                                                                                                                                                                                |
| 19:16         | R          | 0x0         | LPRX_STA_CLK<br>0000: LP00S<br>0001: LP01S<br>0010: LP10S<br>0011: LP11S<br>0100: TRNDS<br>0101: HS_S<br>0110: LPDTS<br>0111: ESCPS<br>1000: ULPSS<br>1001: RSETS<br>1010: UDF1S |

|       |   |     |                                                                                                                                                                                                                                             |
|-------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |   |     | 1011: UDF2S<br>1100: UDF3S<br>1101: UDF4S<br>1110: UDF5S                                                                                                                                                                                    |
| 15:12 | R | 0x0 | LPRX_STA_D3<br>0000: LP00S<br>0001: LP01S<br>0010: LP10S<br>0011: LP11S<br>0100: TRNDS<br>0101: HS_S<br>0110: LPDTS<br>0111: ESCPS<br>1000: ULPSS<br>1001: RSETS<br>1010: UDF1S<br>1011: UDF2S<br>1100: UDF3S<br>1101: UDF4S<br>1110: UDF5S |
| 11:8  | R | 0x0 | LPRX_STA_D2<br>0000: LP00S<br>0001: LP01S<br>0010: LP10S<br>0011: LP11S<br>0100: TRNDS<br>0101: HS_S<br>0110: LPDTS<br>0111: ESCPS<br>1000: ULPSS<br>1001: RSETS<br>1010: UDF1S<br>1011: UDF2S<br>1100: UDF3S<br>1101: UDF4S<br>1110: UDF5S |
| 7:4   | R | 0x0 | LPRX_STA_D1<br>0000: LP00S<br>0001: LP01S<br>0010: LP10S<br>0011: LP11S<br>0100: TRNDS<br>0101: HS_S<br>0110: LPDTS<br>0111: ESCPS                                                                                                          |

|     |   |     |                                                                                                                                                                                                                                             |
|-----|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |   |     | 1000: ULPSS<br>1001: RSETS<br>1010: UDF1S<br>1011: UDF2S<br>1100: UDF3S<br>1101: UDF4S<br>1110: UDF5S                                                                                                                                       |
| 3:0 | R | 0x0 | LPRX_STA_D0<br>0000: LP00S<br>0001: LP01S<br>0010: LP10S<br>0011: LP11S<br>0100: TRNDS<br>0101: HS_S<br>0110: LPDTS<br>0111: ESCPS<br>1000: ULPSS<br>1001: RSETS<br>1010: UDF1S<br>1011: UDF2S<br>1100: UDF3S<br>1101: UDF4S<br>1110: UDF5S |

#### 6.2.6.76. 0x10F0 DPHY Debug 4 Register(Default Value: 0x0000\_0000)

| Offset:0x10F0 |            |             | Register Name: DPHY_DBG4_REG                                     |
|---------------|------------|-------------|------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                      |
| 31:26         | /          | /           | /                                                                |
| 25:24         | R          | 0x0         | LPCD_PHY_CLK<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11 |
| 23:22         | R          | 0x0         | LPCD_PHY_D3<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 21:20         | R          | 0x0         | LPCD_PHY_D2<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |

|       |   |     |                                                                  |
|-------|---|-----|------------------------------------------------------------------|
| 19:18 | R | 0x0 | LPCD_PHY_D1<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 17:16 | R | 0x0 | LPCD_PHY_D0<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 15:10 | / | /   | /                                                                |
| 9:8   | R | 0x0 | LPRX_PHY_CLK<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11 |
| 7:6   | R | 0x0 | LPRX_PHY_D3<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 5:4   | R | 0x0 | LPRX_PHY_D2<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 3:2   | R | 0x0 | LPRX_PHY_D1<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |
| 1:0   | R | 0x0 | LPRX_PHY_D0<br>00: LP-00<br>01: LP-01<br>10: LP-10<br>11: LP-11  |

#### 6.2.6.77. 0x10F4 DPHY Debug 5 Register(Default Value: 0x0000\_0000)

| Offset:0x10F4 |            |             | Register Name: DPHY_DBG5_REG                        |
|---------------|------------|-------------|-----------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                         |
| 31:0          | R          | 0x0         | HSRX_DATA<br>Bit31-24: LANE_D3<br>Bit23-16: LANE_D2 |

|  |  |  |                                        |
|--|--|--|----------------------------------------|
|  |  |  | Bit15-08: LANE_D1<br>Bit07-00: LANE_D0 |
|--|--|--|----------------------------------------|

#### 6.2.6.78. 0x10F8 DPHY TX Skew Register0(Default Value: 0x0000\_0000)

| Offset:0x10F8 |            |             | Register Name: DPHY_TX_SKew_REG0                                                                  |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                       |
| 31:24         | R/W        | 0x0         | SKEWCAL_zero_set<br>The time length of HS-Zero in Skew Calibration mode<br>Its unit is byteclk.   |
| 23:16         | R/W        | 0x0         | SKEWCAL_trail_set<br>The time length of HS-Trail in Skew Calibration mode<br>Its unit is byteclk. |
| 15:8          | R/W        | 0x0         | reg_skewcal<br>Clock Pattern Content : 8'b0101_0101/8'b1010_1010                                  |
| 7:0           | R/W        | 0x0         | reg_skewcal_sync<br>Skewcal sync Pattern Content : 8'b1111_1111                                   |

#### 6.2.6.79. 0x10FC DPHY TX Skew Register1(Default Value: 0x0000\_0000)

| Offset:0x10FC |            |             | Register Name: DPHY_TX_SKew_REG1                                                      |
|---------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                           |
| 31:24         | R/W        | 0x0         | SKEWCAL_sync_set<br>The time length of SkewCal-Sync.<br>Its unit is byteclk.          |
| 23:16         | R/W        | 0x0         | SKEWCAL_pedic_set<br>The time length of Periodic mode SkewCal<br>Its unit is byteclk. |
| 15:0          | R/W        | 0x0         | SKEWCAL_init_set<br>The time length of Initial mode SkewCal<br>Its unit is byteclk.   |

#### 6.2.6.80. 0x1100 DPHY TX Skew Register2(Default Value: 0x0000\_0000)

| Offset:0x1100 |            |             | Register Name: DPHY_TX_SKew_REG2                  |
|---------------|------------|-------------|---------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                       |
| 10            | R/W        | 0x0         | en_skewcal_init                                   |
| 9             | R/W        | 0x0         | en_skewcal_perdic                                 |
| 8             | R/W        | 0x0         | skewcal_trail_inv                                 |
| 7:0           | R/W        | 0x0         | SKEWCAL_PREPARE_LP00<br>The time length of LP-00. |

|  |  |  |                      |
|--|--|--|----------------------|
|  |  |  | Its unit is byteclk. |
|--|--|--|----------------------|

#### 6.2.6.81. 0x1104 DPHY PLL Register0(Default Value: 0x00F0\_3283)

| Offset:0x1104 |            |             | Register Name: DPHY_PLL_REG0                    |
|---------------|------------|-------------|-------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                     |
| 23            | R/W        | 0x1         | cp36_en<br>enable signal of cp for 3.3V voltage |
| 22            | R/W        | 0x1         | ldo_en<br>enable signal of 0.9V LDO for V &dV   |
| 21            | R/W        | 0x1         | en_lvs<br>enable gating for l2h level_shift     |
| 20            | R/W        | 0x1         | pll_en<br>enable_signal for PLL                 |
| 19:16         | R/W        | 0x0         | p<3:0><br>pre divider = p+1;                    |
| 15:8          | R/W        | 0x32        | n<7:0><br>feedback divider = n, except 0;       |
| 7             | R/W        | 0x1         | ndet<br>n detection                             |
| 6             | R/W        | 0x0         | tdiv                                            |
| 5:4           | R/W        | 0x0         | m0<1:0><br>post divider0= 1/2/4                 |
| 3:0           | R/W        | 0x3         | m1<3:0><br>post divider1= m1+1                  |

#### 6.2.6.82. 0x1108 DPHY PLL Register1(Default Value: 0x0000\_0481)

| Offset:0x1108 |            |             | Register Name: DPHY_PLL_REG1                                                          |
|---------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                           |
| 15:14         | R/W        | 0x0         | unlock_mdsel<br>00: 21-29 clock cycles<br>01: 22-28 clock cycles                      |
| 13            | R/W        | 0x0         | lockmdsel<br>0: 24-26 clock cycles<br>1: 23-27 clock cycles                           |
| 12            | R/W        | 0x0         | lockdet_en<br>0: disable<br>1: enable                                                 |
| 11:9          | R/W        | 0x2         | vseta<2:0><br>ref voltage regulation for LDO V<br>0.8,0.85,0.9,0.95,1.0,1.05,1.1,1.15 |

|     |     |     |                                                                                                                                                   |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:6 | R/W | 0x2 | vsetd<2:0><br>ref voltage regulation for LDO dV<br>0.8,0.85,0.9,0.95,1.0,1.05,1.1,1.15                                                            |
| 5   | R/W | 0x0 | lpf_sw<br>charge pump current regulation                                                                                                          |
| 4:3 | R/W | 0x0 | icp_sel<1:0><br>Charge pump current sel & regulate<br>icpsel<1>: current regulate;<br>icpsel<0>: 0 for ibias current;<br>1 for self-bias current; |
| 2:1 | R/W | 0x0 | atest_sel<1:0><br>00: dv<br>01: v<br>10: icp<br>11: vc_od                                                                                         |
| 0   | R/W | 0x1 | test_en<br>test enable for ck_test & ana_test                                                                                                     |

#### 6.2.6.83. 0x1110 COMBO PHY Register0(Default Value: 0x0000\_0000)

| Offset:0x1110 |            |             | Register Name: COMBO_PHY_REG0                |
|---------------|------------|-------------|----------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                  |
| 5             | R/W        | 0x0         | en_test_combaldo<br>combaldo ldo test enable |
| 4             | R/W        | 0x0         | en_test_0p8<br>0p8 ldo test enable           |
| 3             | R/W        | 0x0         | en_mipi<br>mipi phy enable                   |
| 2             | R/W        | 0x0         | en_lvds<br>lvds phy enable                   |
| 1             | R/W        | 0x0         | en_combaldo<br>combaldo enable               |
| 0             | R/W        | 0x0         | en_cp<br>charge pump enable                  |

#### 6.2.6.84. 0x1114 COMBO PHY Register1(Default Value: 0x0000\_0000)

| Offset:0x1114 |            |             | Register Name: COMBO_PHY_REG1 |
|---------------|------------|-------------|-------------------------------|
| Bit           | Read/Write | Default/Hex | Description                   |
| 6:4           | R/W        | 0x0         | reg_vref1p6<br>vref1p6 tuning |
| 3             | /          | /           | /                             |

|     |     |     |                               |
|-----|-----|-----|-------------------------------|
| 2:0 | R/W | 0x0 | reg_vref0p8<br>vref0p8 tuning |
|-----|-----|-----|-------------------------------|

Confidential

## Contents

|                                   |     |
|-----------------------------------|-----|
| Chapter 7 ISP.....                | 510 |
| 7.1. Overview .....               | 510 |
| 7.2. Block Diagram .....          | 511 |
| 7.3. Module Functions .....       | 511 |
| 7.3.1. TDM.....                   | 511 |
| 7.3.2. Crop.....                  | 511 |
| 7.3.3. BLC.....                   | 512 |
| 7.3.4. Digital Gain.....          | 512 |
| 7.3.5. DPC.....                   | 512 |
| 7.3.6. Crosstalk Correction ..... | 512 |
| 7.3.7. GCA.....                   | 512 |
| 7.3.8. 2D De-noise.....           | 512 |
| 7.3.9. WB.....                    | 512 |
| 7.3.10. LSC.....                  | 512 |
| 7.3.11. Bayer Interpolation ..... | 513 |
| 7.3.12. Sharpen .....             | 513 |
| 7.3.13. LCA .....                 | 513 |
| 7.3.14. Color Matrix .....        | 513 |
| 7.3.15. CNR.....                  | 513 |
| 7.3.16. SATU .....                | 513 |
| 7.3.17. DRC .....                 | 513 |
| 7.3.18. Gamma .....               | 514 |
| 7.3.19. RGB2YCrCb .....           | 514 |
| 7.3.20. CEM .....                 | 514 |

## Figures

---

Figure 7- 1. ISP Block Diagram ..... 511

Confidential

# Chapter 7 ISP

## 7.1. Overview

The ISP module supports online/offline image process for RAW sensor. The main functions are as follows.

- Time Division Multiplexing(TDM)
- Crop
- Black level correction(BLC)
- Linearity correction
- Digital gain
- Defect pixel correction(DPC)
- Crosstalk correction
- Global chromatic aberration correction(GCA)
- 2D denoise fileter
- White balance(WB)
- Lens shading correction(LSC)
- Bayer interpolation
- Local chromatic aberration correction(LCA)
- Sharpening
- Color matrix
- Chrominance noise reduction(CNR)
- Saturation adjust
- RGB Dynamic range compression(DRC)
- RGB Gamma correction
- RGB2YCbCr
- Color enhance management
- 3A statistic output
- Anti-flick detection statistics
- Histogram statistics

The processing capability of the ISP module is as follows.

- Supports 8/10/12 bits RAW data input
- supports one sensor in online mode, or two sensors in offline mode
- Supports maximum 16x fps difference among two input cameras
- Online mode: maximum picture resolution of 3264 x 3264, maximum frame rate of 8M@30fps
- Offline mode: maximum picture resolution of 4224 x 4224, maximum frame rate of 13M@10fps
- Minimum picture resolution of 256 x 128
- Minimum horizontal blanking region of 96 pixels

- Minimum vertical blanking region of 40 lines

## 7.2. Block Diagram

The block diagram of the ISP module is as follows.



Figure 7- 1. ISP Block Diagram

## 7.3. Module Functions

### 7.3.1. TDM

The TDM module can support two input cameras simultaneously.

### 7.3.2. Crop

The Crop module can crop the input picture, and often be used to change the aspect ratio of the input picture or extract the region of interest for a picture.

### 7.3.3. BLC

The BLC module adds respectively offset for four Bayer color channels(R,Gr,Gb, and B), to perform optical black correction. The precision of the offset is S13. The module is usually used for wide dynamic sensor.

### 7.3.4. Digital Gain

The Digital Gain module provides the digital gain, and supports U16Q10-precision.

### 7.3.5. DPC

The DPC module is used to correct defect pixels in Bayer field. It supports correct the type of defective pixel: Singlet dead pixel; doublet dead pixel in 5x5 kernel; and other cluster of defect pixel.

### 7.3.6. Crosstalk Correction

The Crosstalk Correction module is used to remove abnormal picture question when Gr and Gb imbalance. Usually, the module is used when sensor CRA unmatches lens CRA.

### 7.3.7. GCA

The GCA module is used to correction of Lateral Chromatic Aberration, which is one of the common optical defects of camera lens.

### 7.3.8. 2D De-noise

The 2D De-noise module restrains sensor noises in the Bayer field to improve picture quality.

### 7.3.9. WB

The WB Correction module adds respectively gain for four channels(R, Gr ,Gb, and B) to implement white balance correction. The precision of the gain is U12Q8.

### 7.3.10. LSC

The LSC module implements lens shading correction. It supports two way of mesh(MSC) and radio(RSC), which interpolate the shading correction coefficient by the radio distance and pixel block statistics.

### 7.3.11. Bayer Interpolation

The module interpolates Bayer field pixel to RGB field while holding clear picture edge and restraining pseudo color.

### 7.3.12. Sharpen

The Sharpen module implements picture edge sharpening to improve picture edge information, while picture contour is much clearer.

### 7.3.13. LCA

The LCA module is used to correction of Axial Chromatic Aberration, which is one of the common optical defects of camera lens.

### 7.3.14. Color Matrix

The Color Matrix module applies a 3x3 color gain matrix and a 3x1 offset matrix on the input R/G/B pixels to restore image color. The precision of each value in gain matrix is S12Q8 and the precision of each value in offset matrix is S13.

$$\begin{pmatrix} R\_out \\ G\_out \\ B\_out \end{pmatrix} = \begin{pmatrix} g_{rr} & g_{gr} & g_{br} \\ g_{rg} & g_{gg} & g_{bg} \\ g_{rb} & g_{gb} & g_{bb} \end{pmatrix} \times \begin{pmatrix} R\_in \\ G\_in \\ B\_in \end{pmatrix} + \begin{pmatrix} offset\_R \\ offset\_G \\ offset\_B \end{pmatrix}$$

### 7.3.15. CNR

The CNR module is used to reduce chroma noise in RGB domain.

### 7.3.16. SATU

Saturation adjust module is used to adjust the saturation of image.

### 7.3.17. DRC

The DRC module performs a gamma correction for each color in the RGB color space.

### 7.3.18. Gamma

The Gamma module applies gamma correction for each color channel(R,G, and B) through looking-up table. Each gamma table has 256 entries and the precision is U12.

### 7.3.19. RGB2YCrCb

The RGB2YCrCb module convert RGB color space to YCbCr color space by using a 3x3 square matrix with an added offset. Each gain range is U10Q10 precision.

### 7.3.20. CEM

The CEM module adjusts hue and saturation of picture in YUV field, and enhances or restrains specific colors such as blue sky, plant and complexion based on user preference.

## Contents

|                                                     |     |
|-----------------------------------------------------|-----|
| Chapter 8 Video Input Interfaces.....               | 518 |
| 8.1. CSIC .....                                     | 518 |
| 8.1.1. Overview .....                               | 518 |
| 8.1.2. Block Diagram .....                          | 518 |
| 8.1.3. Operations and Functional Descriptions ..... | 519 |
| 8.1.4. Register List .....                          | 521 |
| 8.1.5. CCU Register Description .....               | 525 |
| 8.1.6. CSIC Top Register Description.....           | 527 |
| 8.1.7. Parser Register Description .....            | 546 |
| 8.1.8. CSIC DMA Register Description .....          | 562 |

## Figures

|                                                 |     |
|-------------------------------------------------|-----|
| Figure 8- 1. CSIC Block Diagram .....           | 518 |
| Figure 8- 2. RAW-10 Format .....                | 520 |
| Figure 8- 3. RAW-12 Format .....                | 520 |
| Figure 8- 4. Y of YUV-10 Format.....            | 520 |
| Figure 8- 5. UV Combined of YUV-10 Format ..... | 520 |
| Figure 8- 6. RGB888 Format.....                 | 520 |
| Figure 8- 7. PRGB888 Format.....                | 521 |
| Figure 8- 8. RGB565 Format.....                 | 521 |

## Tables

---

|                                          |     |
|------------------------------------------|-----|
| Table 8- 1. CSIC External Signals .....  | 519 |
| Table 8- 2. CSIC FIFO Distribution ..... | 519 |

Confidential

# Chapter 8 Video Input Interfaces

## 8.1. CSIC

### 8.1.1. Overview

The CMOS Sensor Interface Controller(CSIC) is an image or video input control module which can receive image or video data via camera interface(MIPI). The controller can transfer valid data to embedded ISP or store the data in memory directly.

The CSIC includes the following features:

- Supports 2 serial interfaces(one for MIPI 4-lane, the other for MIPI 2-lane)
- Supports image crop function
- Supports MIPI Version 1.0
- Up to 1.0Gbps/Lane
- Maximum video capture resolution for serial interface up to 8M@30fps(online mode) or 13M@10fps(offline mode) or 4\*1080p@25fps(de-interleaver conversion chip)

### 8.1.2. Block Diagram

Figure 8-1 shows a function block diagram of the CSIC. The CSIC consists of Input Parser, ISP, VIPP and DMA Control. In addition, the controller has 2 Input Parsers, 1 ISP, 4 VIPPs and 4 DMAs.



Figure 8- 1. CSIC Block Diagram

### 8.1.3. Operations and Functional Descriptions

#### 8.1.3.1. External Signals

Table 8- 1. CSIC External Signals

| Signal     | Description                                 | Type |
|------------|---------------------------------------------|------|
| MCSIA_CKN  | MIPI CSI controller A clock negative signal | AI   |
| MCSIA_CKP  | MIPI CSI controller A clock positive signal | AI   |
| MCSIA_D0N  | MIPI CSI controller A data0 negative signal | AI   |
| MCSIA_D0P  | MIPI CSI controller A data0 positive signal | AI   |
| MCSIA_D1N  | MIPI CSI controller A data1 negative signal | AI   |
| MCSIA_D1P  | MIPI CSI controller A data1 positive signal | AI   |
| MCSIA_D2N  | MIPI CSI controller A data2 negative signal | AI   |
| MCSIA_D2P  | MIPI CSI controller A data2 positive signal | AI   |
| MCSIA_D3N  | MIPI CSI controller A data3 negative signal | AI   |
| MCSIA_D3P  | MIPI CSI controller A data3 positive signal | AI   |
| MCSIB_CKN  | MIPI CSI controller B clock negative signal | AI   |
| MCSIB_CKP  | MIPI CSI controller B clock positive signal | AI   |
| MCSIB_D0N  | MIPI CSI controller B data0 negative signal | AI   |
| MCSIB_D0P  | MIPI CSI controller B data0 positive signal | AI   |
| MCSIB_D1N  | MIPI CSI controller B data1 negative signal | AI   |
| MCSIB_D1P  | MIPI CSI controller B data1 positive signal | AI   |
| VCC_MCSI   | MIPI CSI power supply                       | P    |
| MIPI_MCLK0 | MIPI CSI controller A master clock          | O    |
| MIPI_MCLK1 | MIPI CSI controller B master clock          | O    |
| CSI_SM_VS  | MIPI CSI slave mode vertical SYNC           | O    |

#### 8.1.3.2. Typical Application

The CSIC has 2 input ports and 4 DMA, which means it can support 2 port input and 4 video streams output to memory simultaneously at most. This makes the applications very flexible.

The CSIC supports following input case:

- 2 serial inputs(1 four-lane and 1 two-lane)

#### 8.1.3.3. CSIC FIFO Distribution

Table 8- 2. CSIC FIFO Distribution

| Interface | MIPI Interface |
|-----------|----------------|
|           |                |

|               |        |             |                 |
|---------------|--------|-------------|-----------------|
| Input format  | YUV422 |             | Raw             |
| Output format | Planar | UV combined | Raw/RGB/PRGB    |
| CHO_FIFO0     | Y      | Y           | All pixels data |
| CHO_FIFO1     | Cb (U) | CbCr (UV)   | -               |
| CHO_FIFO2     | Cr (V) | -           | -               |

#### 8.1.3.4. Pixel Format Arrangement

**RAW-10:**



Figure 8- 2. RAW-10 Format

**RAW-12:**



Figure 8- 3. RAW-12 Format

**YUV-10:**



Figure 8- 4. Y of YUV-10 Format



Figure 8- 5. UV Combined of YUV-10 Format

**RGB888:**



Figure 8- 6. RGB888 Format

**PRGB888:**



## Figure 8- 7. PRGB888 Format

## RGB565:



## Figure 8- 8. RGB565 Format

### 8.1.3.5. Offset Definition

Offset in horizontal and vertical can be added when receiving image. Unit is pixel.

For YUV422 format, pixel unit is a YU/YV combination.

For YUV420 format, pixel unit is a YU/YV combination in YC line, and only a Y in Y line.

For Bayer and RAW format, pixel unit is a R/G/B single component.

For RGB565, pixel unit is 2 bytes of RGB565 package.

For RGB888, pixel unit is 3 bytes of RGB combination.

### 8.1.3.6. Flip Definition

Both horizontal and vertical flip are supported at the same time. This function is implemented in the process of each FIFO writing data to memory, only flipping the data of separate FIFO, not changing component to FIFO distribution.

If horizontal flip is enabled, one or more pixels will be took as a unit:

For YUV format, a unit of  $Y_0U_0Y_1V_1$  will parse and flip the Y component in one channel, and UV will be treated as a whole. In planar output mode, U and V will be flipped separately. In UV combined output mode, UV will be flipped as a whole. So, a sequence of  $Y_1U_0Y_0V_1$  will be.

For Bayer\_raw format, situation is much like. A GR/BG sequence will be changed to BG/RG. A unit of square has four pixels.

For RGB565/RGB888, one unit of two/three bytes of component will be flipped with original sequence.

#### **8.1.4. Register List**

| Module Name | Base Address |
|-------------|--------------|
| CSIC_BASE   | 0x02000000   |
| CSIC_CCU    | 0x02000000   |

|              |            |
|--------------|------------|
| CSIC_TOP     | 0x02000800 |
| CSIC_PARSER0 | 0x02001000 |
| CSIC_PARSER1 | 0x02002000 |
| CSIC_DMA0    | 0x02009000 |
| CSIC_DMA1    | 0x02009200 |
| CSIC_DMA2    | 0x02009400 |
| CSIC_DMA3    | 0x02009600 |
| CSIC_COMBO   | 0x0200A000 |
| CSIC_ISP0    | 0x02100000 |
| CSIC_ISP1    | 0x02102000 |
| CSIC_TDM     | 0x02108000 |
| CSIC_VIPPO   | 0x02110000 |
| CSIC_VIPP1   | 0x02110400 |
| CSIC_VIPP2   | 0x02110800 |
| CSIC_VIPP3   | 0x02110C00 |

CCU register list:

| Register Name         | Offset | Register Description             |
|-----------------------|--------|----------------------------------|
| CCU_CLK_MODE_REG      | 0x0000 | CCU Clock Mode Register          |
| CCU_PARSER_CLK_EN_REG | 0x0004 | CCU Parser Clock Enable Register |
| CCU_ISP_CLK_EN_REG    | 0x0008 | CCU ISP Clock Enable Register    |
| CCU_POST0_CLK_EN_REG  | 0x000C | CCU Post0 Clock Enable Register  |

CSIC TOP register list:

| Register Name            | Offset | Register Description                     |
|--------------------------|--------|------------------------------------------|
| CSIC_TOP_EN_REG          | 0x0000 | CSIC TOP Enable Register                 |
| CSIC_PTN_GEN_EN_REG      | 0x0004 | CSIC Pattern Generation Enable Register  |
| CSIC_PTN_CTRL_REG        | 0x0008 | CSIC Pattern Control Register            |
| CSIC_PTN_LEN_REG         | 0x0020 | CSIC Pattern Generation Length Register  |
| CSIC_PTN_ADDR_REG        | 0x0024 | CSIC Pattern Generation Address Register |
| CSIC_PTN_ISP_SIZE_REG    | 0x0028 | CSIC Pattern ISP Size Register           |
| CSIC_ISP0_INPUT0_SEL_REG | 0x0030 | CSIC ISP0 Input0 Select Register         |
| CSIC_ISP0_INPUT1_SEL_REG | 0x0034 | CSIC ISP0 Input1 Select Register         |
| CSIC_ISP0_INPUT2_SEL_REG | 0x0038 | CSIC ISP0 Input2 Select Register         |
| CSIC_ISP0_INPUT3_SEL_REG | 0x003C | CSIC ISP0 Input3 Select Register         |
| CSIC_ISP1_INPUT0_SEL_REG | 0x0040 | CSIC ISP1 Input0 Select Register         |
| CSIC_ISP1_INPUT1_SEL_REG | 0x0044 | CSIC ISP1 Input1 Select Register         |
| CSIC_ISP1_INPUT2_SEL_REG | 0x0048 | CSIC ISP1 Input2 Select Register         |
| CSIC_ISP1_INPUT3_SEL_REG | 0x004C | CSIC ISP1 Input3 Select Register         |
| CSIC_ISP2_INPUT0_SEL_REG | 0x0050 | CSIC ISP2 Input0 Select Register         |
| CSIC_ISP2_INPUT1_SEL_REG | 0x0054 | CSIC ISP2 Input1 Select Register         |
| CSIC_ISP2_INPUT2_SEL_REG | 0x0058 | CSIC ISP2 Input2 Select Register         |
| CSIC_ISP2_INPUT3_SEL_REG | 0x005C | CSIC ISP2 Input3 Select Register         |
| CSIC_ISP3_INPUT0_SEL_REG | 0x0060 | CSIC ISP3 Input0 Select Register         |

|                                     |        |                                                      |
|-------------------------------------|--------|------------------------------------------------------|
| CSIC_ISP3_INPUT1_SEL_REG            | 0x0064 | CSIC ISP3 Input1 Select Register                     |
| CSIC_ISP3_INPUT2_SEL_REG            | 0x0068 | CSIC ISP3 Input2 Select Register                     |
| CSIC_ISP3_INPUT3_SEL_REG            | 0x006C | CSIC ISP3 Input3 Select Register                     |
| CSIC_ISP_BRG_BUF_MAXUSE_CNT_CLR_REG | 0x0070 | CSIC ISP Bridge Buffer Maxuse Counter Clear Register |
| CSIC_ISP0_BRG_BUF_MAXUSE_CNT_REG    | 0x0074 | CSIC ISPO Bridge Buffer Maxuse Counter Register      |
| CSIC_ISP1_BRG_BUF_MAXUSE_CNT_REG    | 0x007C | CSIC ISP1 Bridge Buffer Maxuse Counter Register      |
| CSIC_ISP0_BRG_INT_EN_REG            | 0x0084 | CSIC ISPO Bridge Interrupt Enable Register           |
| CSIC_ISP1_BRG_INT_EN_REG            | 0x0088 | CSIC ISP1 Bridge Interrupt Enable Register           |
| CSIC_ISP0_BRG_INT_PD_REG            | 0x008C | CSIC ISPO Bridge Interrupt Pending Register          |
| CSIC_ISP1_BRG_INT_PD_REG            | 0x0090 | CSIC ISP1 Bridge Interrupt Pending Register          |
| CSIC_DMA0_INPUT_SEL_REG             | 0x00A0 | CSIC DMA0 Input Select Register                      |
| CSIC_DMA1_INPUT_SEL_REG             | 0x00A4 | CSIC DMA1 Input Select Register                      |
| CSIC_DMA2_INPUT_SEL_REG             | 0x00A8 | CSIC DMA2 Input Select Register                      |
| CSIC_DMA3_INPUT_SEL_REG             | 0x00AC | CSIC DMA3 Input Select Register                      |
| CSIC_BIST_CS_REG                    | 0x00DC | CSIC BIST CS Register                                |
| CSIC_BIST_CONTROL_REG               | 0x00E0 | CSIC BIST Control Register                           |
| CSIC_BIST_START_REG                 | 0x00E4 | CSIC BIST Start Register                             |
| CSIC_BIST_END_REG                   | 0x00E8 | CSIC BIST End Register                               |
| CSIC_BIST_DATA_MASK_REG             | 0x00EC | CSIC BIST Data Mask Register                         |
| CSIC_MBUS_REQ_MAX_REG               | 0x00F0 | CSIC MBUS REQ MAX Register                           |
| CSIC_MULF_MOD_REG                   | 0x0100 | CSIC Multi-Frame Mode Register                       |
| CSIC_MULF_INT_REG                   | 0x0104 | CSIC Multi-Frame Interrupt Register                  |
| CSIC_FEATURE_LIST_REG               | 0x01F0 | CSIC Feature list Register                           |

PARSER0/1 register list:

| Register Name           | Offset | Register Description                             |
|-------------------------|--------|--------------------------------------------------|
| PRS_EN_REG              | 0x0000 | Parser Enable Register                           |
| PRS_MCSIC_IF_CFG_REG    | 0x0008 | Parser MCSIC Interface Configuration Register    |
| PRS_CAP_REG             | 0x000C | Parser Capture Register                          |
| PRS_CO_INFMT_REG        | 0x0024 | Parser Channel_0 Input Format Register           |
| PRS_CO_OUTPUT_HSIZE_REG | 0x0028 | Parser Channel_0 Output Horizontal Size Register |
| PRS_CO_OUTPUT_VSIZE_REG | 0x002C | Parser Channel_0 Output Vertical Size Register   |
| PRS_CO_INPUT_PARAO_REG  | 0x0030 | Parser Channel_0 Input Parameter0 Register       |
| PRS_CO_INPUT_PARA1_REG  | 0x0034 | Parser Channel_0 Input Parameter1 Register       |
| PRS_CO_INPUT_PARA2_REG  | 0x0038 | Parser Channel_0 Input Parameter2 Register       |
| PRS_CO_INPUT_PARA3_REG  | 0x003C | Parser Channel_0 Input Parameter3 Register       |
| PRS_CO_INT_EN_REG       | 0x0040 | Parser Channel_0 Interrupt Enable Register       |
| PRS_CO_INT_STA_REG      | 0x0044 | Parser Channel_0 Interrupt Status Register       |
| PRS_CH0_LINE_TIME_REG   | 0x0048 | Parser Channel_0 Line Time Register              |
| PRS_C1_INFMT_REG        | 0x0124 | Parser Channel_1 Input Format Register           |
| PRS_C1_OUTPUT_HSIZE_REG | 0x0128 | Parser Channel_1 Output Horizontal Size Register |
| PRS_C1_OUTPUT_VSIZE_REG | 0x012C | Parser Channel_1 Output Vertical Size Register   |
| PRS_C1_INPUT_PARAO_REG  | 0x0130 | Parser Channel_1 Input Parameter0 Register       |

|                          |        |                                                  |
|--------------------------|--------|--------------------------------------------------|
| PRS_C1_INPUT_PARA1_REG   | 0x0134 | Parser Channel_1 Input Parameter1 Register       |
| PRS_C1_INPUT_PARA2_REG   | 0x0138 | Parser Channel_1 Input Parameter2 Register       |
| PRS_C1_INPUT_PARA3_REG   | 0x013C | Parser Channel_1 Input Parameter3 Register       |
| PRS_C1_INT_EN_REG        | 0x0140 | Parser Channel_1 Interrupt Enable Register       |
| PRS_C1_INT_STA_REG       | 0x0144 | Parser Channel_1 Interrupt Status Register       |
| PRS_CH1_LINE_TIME_REG    | 0x0148 | Parser Channel_1 Line Time Register              |
| PRS_C2_INFMT_REG         | 0x0224 | Parser Channel_2 Input Format Register           |
| PRS_C2_OUTPUT_HSIZE_REG  | 0x0228 | Parser Channel_2 Output Horizontal Size Register |
| PRS_C2_OUTPUT_VSIZE_REG  | 0x022C | Parser Channel_2 Output Vertical Size Register   |
| PRS_C2_INPUT_PARA0_REG   | 0x0230 | Parser Channel_2 Input Parameter0 Register       |
| PRS_C2_INPUT_PARA1_REG   | 0x0234 | Parser Channel_2 Input Parameter1 Register       |
| PRS_C2_INPUT_PARA2_REG   | 0x0238 | Parser Channel_2 Input Parameter2 Register       |
| PRS_C2_INPUT_PARA3_REG   | 0x023C | Parser Channel_2 Input Parameter3 Register       |
| PRS_C2_INT_EN_REG        | 0x0240 | Parser Channel_2 Interrupt Enable Register       |
| PRS_C2_INT_STA_REG       | 0x0244 | Parser Channel_2 Interrupt Status Register       |
| PRS_CH2_LINE_TIME_REG    | 0x0248 | Parser Channel_2 Line Time Register              |
| PRS_C3_INFMT_REG         | 0x0324 | Parser Channel_3 Input Format Register           |
| PRS_C3_OUTPUT_HSIZE_REG  | 0x0328 | Parser Channel_3 Output Horizontal Size Register |
| PRS_C3_OUTPUT_VSIZE_REG  | 0x032C | Parser Channel_3 Output Vertical Size Register   |
| PRS_C3_INPUT_PARA0_REG   | 0x0330 | Parser Channel_3 Input Parameter0 Register       |
| PRS_C3_INPUT_PARA1_REG   | 0x0334 | Parser Channel_3 Input Parameter1 Register       |
| PRS_C3_INPUT_PARA2_REG   | 0x0338 | Parser Channel_3 Input Parameter2 Register       |
| PRS_C3_INPUT_PARA3_REG   | 0x033C | Parser Channel_3 Input Parameter3 Register       |
| PRS_C3_INT_EN_REG        | 0x0340 | Parser Channel_3 Interrupt Enable Register       |
| PRS_C3_INT_STA_REG       | 0x0344 | Parser Channel_3 Interrupt Status Register       |
| PRS_CH3_LINE_TIME_REG    | 0x0348 | Parser Channel_3 Line Time Register              |
| PRS_CSIC_SYNC_EN_REG     | 0x0520 | Parser CSIC SYNC Enable Register                 |
| PRS_CSIC_SYNC_CFG_REG    | 0x0524 | Parser CSIC SYNC CFG Register                    |
| PRS_CSIC_SYNC_WAIT_N_REG | 0x0528 | Parser CSIC SYNC WAIT N Register                 |
| PRS_CSIC_SYNC_WAIT_M_REG | 0x052C | Parser CSIC SYNC WAIT M Register                 |

#### DMA0/1/2/3 register list:

|                             |        |                                                         |
|-----------------------------|--------|---------------------------------------------------------|
| CSIC_DMA_EN_REG             | 0x0000 | CSIC DMA Enable Register                                |
| CSIC_DMA_CFG_REG            | 0x0004 | CSIC DMA Configuration Register                         |
| CSIC_DMA_HSIZE_REG          | 0x0010 | CSIC DMA Horizontal Size Register                       |
| CSIC_DMA_VSIZE_REG          | 0x0014 | CSIC DMA Vertical Size Register                         |
| CSIC_DMA_F0_BUFA_REG        | 0x0020 | CSIC DMA FIFO 0 Output Buffer-A Address Register        |
| CSIC_DMA_F0_BUFA_RESULT_REG | 0x0024 | CSIC DMA FIFO 0 Output Buffer-A Address Result Register |
| CSIC_DMA_F1_BUFA_REG        | 0x0028 | CSIC DMA FIFO 1 Output Buffer-A Address Register        |
| CSIC_DMA_F1_BUFA_RESULT_REG | 0x002C | CSIC DMA FIFO 1 Output Buffer-A Address Result Register |
| CSIC_DMA_F2_BUFA_REG        | 0x0030 | CSIC DMA FIFO 2 Output Buffer-A Address Register        |

|                                   |        |                                                          |
|-----------------------------------|--------|----------------------------------------------------------|
| CSIC_DMA_F1_BUFA_RESULT_REG       | 0x0034 | CSIC DMA FIFO 2 Output Buffer-A Address Result Register  |
| CSIC_DMA_BUF_LEN_REG              | 0x0038 | CSIC DMA Buffer Length Register                          |
| CSIC_DMA_FLIP_SIZE_REG            | 0x003C | CSIC DMA Flip Size Register                              |
| CSIC_DMA_VI_TO_TH0_REG            | 0x0040 | CSIC DMA Video Input Timeout Threshold0 Register         |
| CSIC_DMA_VI_TO_TH1_REG            | 0x0044 | CSIC DMA Video Input Timeout Threshold1 Register         |
| CSIC_DMA_VI_TO_CNT_VAL_REG        | 0x0048 | CSIC DMA Video Input Timeout Counter Value Register      |
| CSIC_DMA_CAP_STA_REG              | 0x004C | CSIC DMA Capture Status Register                         |
| CSIC_DMA_INT_EN_REG               | 0x0050 | CSIC DMA Interrupt Enable Register                       |
| CSIC_DMA_INT_STA_REG              | 0x0054 | CSIC DMA Interrupt Status Register                       |
| CSIC_DMA_LINE_CNT_REG             | 0x0058 | CSIC DMA LINE Counter Register                           |
| CSIC_DMA_FRM_CNT_REG              | 0x005C | CSIC DMA Frame Counter Register                          |
| CSIC_DMA_FRM_CLK_CNT_REG          | 0x0060 | CSIC DMA Frame Clock Counter Register                    |
| CSIC_DMA_ACC_ITNL_CLK_CNT_REG     | 0x0064 | CSIC DMA Accumulated And Internal Clock Counter Register |
| CSIC_DMA_FIFO_STAT_REG            | 0x0068 | CSIC DMA FIFO Statistic Register                         |
| CSIC_DMA_FIFO_THRS_REG            | 0x006C | CSIC DMA FIFO Threshold Register                         |
| CSIC_DMA_PCLK_STAT_REG            | 0x0070 | CSIC DMA PCLK Statistic Register                         |
| CSIC_DMA_BUF_ADDR_FIFO0_ENTRY_REG | 0x0080 | CSIC DMA BUF Address FIFO0 Entry Register                |
| CSIC_DMA_BUF_ADDR_FIFO1_ENTRY_REG | 0x0084 | CSIC DMA BUF Address FIFO1 Entry Register                |
| CSIC_DMA_BUF_ADDR_FIFO2_ENTRY_REG | 0x0088 | CSIC DMA BUF Address FIFO2 Entry Register                |
| CSIC_DMA_BUF_TH_REG               | 0x008C | CSIC DMA BUF Threshold Register                          |
| CSIC_DMA_BUF_ADDR_FIFO_CON_REG    | 0x0090 | CSIC DMA BUF Address FIFO Content Register               |
| CSIC_DMA_STORED_FRM_CNT_REG       | 0x0094 | CSIC DMA Stored Frame Counter Register                   |
| CSIC_LBC_CONFIG_REG               | 0x0100 | CSIC LBC Configure Register                              |
| CSIC_LBC_LINE_TAR_BIT0_REG        | 0x0104 | CSIC LBC Line Target Bit0 Register                       |
| CSIC_LBC_LINE_TAR_BIT1_REG        | 0x0108 | CSIC LBC Line Target Bit1 Register                       |
| CSIC_LBC_RC_ADV_REG               | 0x010C | CSIC LBC RC ADV Register                                 |
| CSIC_LBC_MB_MIN_REG               | 0x0110 | CSIC LBC MB MIN Register                                 |
| CSIC_FEATURE_REG                  | 0x01F4 | CSIC DMA Feature List Register                           |

### 8.1.5. CCU Register Description

#### 8.1.5.1. 0x0000 CCU Clock Mode Register(Default Value:0x8000\_0000)

| Offset: 0x0000 |            |             | Register Name: CCU_CLK_MODE_REG                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31             | R/W        | 0x1         | CCU_CLK_GATING_DISABLE<br>0: CCU Clock Gating Registers(0x0004~0x0010) effect<br>1: CCU Clock Gating Registers(0x0004~0x0010) not effect |
| 30:5           | /          | /           | /                                                                                                                                        |
| 4              | R/W        | 0x0         | MISP_CLK_MODE                                                                                                                            |

|     |     |     |                                                                                                                                             |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0: ISP core clock uses isp_clk2x when there is only 1 isp core working<br>1: ISP core clock uses isp_clk1x when there is 2 isp core working |
| 3:2 | /   | /   | /                                                                                                                                           |
| 1   | R/W | 0x0 | MCSI_POST_CLK_MODE<br>0: Reserved<br>1: CSI Post works in csi clock                                                                         |
| 0   | R/W | 0x0 | MCSI_PARSER_CLK_MODE<br>0: CSI Parser works in isp core clock<br>1: CSI Parser works in csi clock                                           |

#### 8.1.5.2. 0x0004 CCU Parser Clock Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CCU_PARSER_CLK_EN_REG                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:9           | /          | /           | /                                                                                      |
| 8              | R/W        | 0x0         | MCSI_COMBO0_CLK_ENABLE<br>0: Combo0 clock disable<br>1: Combo0 clock enable            |
| 7:2            | /          | /           | /                                                                                      |
| 1              | R/W        | 0x0         | MCSI_PARSER1_CLK_ENABLE<br>0: CSI Parser1 clock disable<br>1: CSI Parser1 clock enable |
| 0              | R/W        | 0x0         | MCSI_PARSER0_CLK_ENABLE<br>0: CSI Parser0 clock disable<br>1: CSI Parser0 clock enable |

#### 8.1.5.3. 0x0008 CCU ISP Clock Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CCU_ISP_CLK_EN_REG                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:6           | /          | /           | /                                                                                      |
| 5              | R/W        | 0x0         | MISP1_BRIDGE_CLK_ENABLE<br>0: ISP1 bridge clock disable<br>1: ISP1 bridge clock enable |
| 4              | R/W        | 0x0         | MISPO_BRIDGE_CLK_ENABLE<br>0: ISPO bridge clock disable<br>1: ISPO bridge clock enable |
| 3:1            | /          | /           | /                                                                                      |
| 0              | R/W        | 0x0         | MISPO_CLK_ENABLE<br>0: ISPO clock disable<br>1: ISPO clock enable                      |

#### 8.1.5.4. 0x000C CCU Post0 Clock Enable Register(Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CCU_POST0_CLK_EN_REG                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:17          | /          | /           | /                                                                                                        |
| 16             | R/W        | 0x0         | MCSI_POST0_CLK_ENABLE<br>0: POST0 clock disable<br>1: POST0 clock enable                                 |
| 15:12          | /          | /           | /                                                                                                        |
| 11             | R/W        | 0x0         | MCSI_VIPP3_CLK_ENABLE<br>0: VIPP3 clock disable<br>1: VIPP3 clock enable,when MCSI_POST0_CLK_ENABLE is 1 |
| 10             | R/W        | 0x0         | MCSI_VIPP2_CLK_ENABLE<br>0: VIPP2 clock disable<br>1: VIPP2 clock enable,when MCSI_POST0_CLK_ENABLE is 1 |
| 9              | R/W        | 0x0         | MCSI_VIPP1_CLK_ENABLE<br>0: VIPP1 clock disable<br>1: VIPP1 clock enable,when MCSI_POST0_CLK_ENABLE is 1 |
| 8              | R/W        | 0x0         | MCSI_VIPPO_CLK_ENABLE<br>0: VIPPO clock disable<br>1: VIPPO clock enable,when MCSI_POST0_CLK_ENABLE is 1 |
| 7:4            | /          | /           | /                                                                                                        |
| 3              | R/W        | 0x0         | MCSI_BK3_CLK_ENABLE<br>0: BK3 clock disable<br>1: BK3 clock enable,when MCSI_POST0_CLK_ENABLE is 1       |
| 2              | R/W        | 0x0         | MCSI_BK2_CLK_ENABLE<br>0: BK2 clock disable<br>1: BK2 clock enable,when MCSI_POST0_CLK_ENABLE is 1       |
| 1              | R/W        | 0x0         | MCSI_BK1_CLK_ENABLE<br>0: BK1 clock disable<br>1: BK1 clock enable,when MCSI_POST0_CLK_ENABLE is 1       |
| 0              | R/W        | 0x0         | MCSI_BK0_CLK_ENABLE<br>0: BK0 clock disable<br>1: BK0 clock enable,when MCSI_POST0_CLK_ENABLE is 1       |

#### 8.1.6. CSIC Top Register Description

##### 8.1.6.1. 0x0000 CSIC TOP Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CSIC_TOP_EN_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:4           | /          | /           | /                              |
| 3              | R/W        | 0x0         | ISP_BRIDGE_EN                  |

|   |     |     |                                                                                                                                          |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Enable Async Bridge from parser to isp and isp to post, when isp uses different clock source from csi_top_clk<br>0: disable<br>1: enable |
| 2 | R/W | 0x0 | BIST_MODE_EN<br>0: Closed<br>1: EN BIST TEST                                                                                             |
| 1 | /   | /   | /                                                                                                                                        |
| 0 | R/W | 0x0 | CSIC_TOP_EN<br>0: Reset and disable the CSIC module<br>1: Enable the CSIC module                                                         |

#### 8.1.6.2. 0x0004 CSIC Pattern Generation Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CSIC_PTN_GEN_EN_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                               |
| 23:16          | R/W        | 0x0         | PTN_CYCLE<br>Pattern generating cycle counter.<br>The pattern in dram will be generated in cycles of PTN_CYCLE+1.                                                                                                                                               |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                               |
| 4              | R/WAC      | 0x0         | PTN_START<br>CSIC Pattern Generating Start<br>0: Finish<br>other: Start<br>Software writes this bit to "1" to start pattern generating from DRAM. When finished, the hardware will clear this bit to "0" automatically. Generating cycles depends on PTN_CYCLE. |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                               |
| 0              | R/W        | 0x0         | PTN_GEN_EN<br>Pattern Generation Enable                                                                                                                                                                                                                         |

#### 8.1.6.3. 0x0008 CSIC Pattern Control Register(Default Value:0x0000\_000F)

| Offset: 0x0008 |            |             | Register Name: CSIC_PTN_CTRL_REG                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:26          | /          | /           | /                                                                                                       |
| 25:24          | R/W        | 0x0         | PTN_PORT_SEL<br>Pattern generator output port selection<br>000:reserved<br>001:reserved<br>010:reserved |

|       |     |     |                                                                                                                                                                               |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 011:reserved<br>100:reserved<br>101:reserved<br>110:COMBO<br>111:reserved                                                                                                     |
| 23:22 | /   | /   | /                                                                                                                                                                             |
| 21:20 | R/W | 0x0 | PTN_GEN_DATA_WIDTH<br>00:8-bit<br>01:10-bit<br>10:12-bit<br>11:reserved                                                                                                       |
| 19:16 | R/W | 0x0 | PTN_MODE<br>Pattern mode selection<br>0000~1011:reserved<br>1100:BAYER 12 bits for ISPFE<br>1101:UYVY422 12 bits for ISPFE<br>1110:UYVY420 12 bits for ISPFE<br>1111:reserved |
| 15:10 | /   | /   | /                                                                                                                                                                             |
| 9:8   | R/W | 0x0 | PTN_GEN_CLK_DIV<br>Packet generator clock divider                                                                                                                             |
| 7:0   | R/W | 0xF | PTN_GEN_DLY<br>Clocks delayed before pattern generating start.                                                                                                                |

#### 8.1.6.4. 0x0020 CSIC Pattern Generation Length Register(Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CSIC_PTN_LEN_REG                                |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:0           | R/W        | 0x0         | PTN_LEN<br>The pattern length in byte when generating pattern. |

#### 8.1.6.5. 0x0024 CSIC Pattern Generation Address Register(Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CSIC_PTN_ADDR_REG                              |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:0           | R/W        | 0x0         | PTN_ADDR<br>The pattern DRAM address when generating pattern. |

#### 8.1.6.6. 0x0028 CSIC Pattern ISP Size Register(Default Value:0x0000\_0000)

| Offset: 0x0028 | Register Name: CSIC_PTN_ISP_SIZE_REG |
|----------------|--------------------------------------|
|----------------|--------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                           |
|-------|------------|-------------|-----------------------------------------------------------------------|
| 31:29 | /          | /           | /                                                                     |
| 28:16 | R/W        | 0x0         | Height<br>Vertical size, only valid for ISP mode pattern generation.  |
| 15:13 | /          | /           | /                                                                     |
| 12:0  | R/W        | 0x0         | Width<br>Horizontal size, only valid for ISP mode pattern generation. |

#### 8.1.6.7. 0x0030 CSIC ISP0 Input0 Select Register(Default Value:0x0000\_0000)

| Offset :0x0030 |            |             | Register Name: CSIC_ISP0_INPUT0_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x0         | ISP0 Input0 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.8. 0x0034 CSIC ISP0 Input1 Select Register(Default Value:0x0000\_0001)

| Offset :0x0034 |            |             | Register Name: CSIC_ISP0_INPUT1_SEL_REG                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                  |
| 3:0            | R/W        | 0x1         | ISP0 Input1 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0 |

|  |  |                                                                                                                                                                                                                                                                                                                                                              |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | 0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.9. 0x0038 CSIC ISP0 Input2 Select Register(Default Value:0x0000\_0002)

| Offset :0x0038 |            |             | Register Name: CSIC_ISP0_INPUT2_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x2         | ISP0 Input2 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.10. 0x003C CSIC ISP0 Input3 Select Register(Default Value:0x0000\_0003)

| Offset :0x003C |            |             | Register Name: CSIC_ISP0_INPUT3_SEL_REG            |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:4           | /          | /           | /                                                  |
| 3:0            | R/W        | 0x3         | ISP0 Input3 Select<br>0000: input from Parser0 CH0 |

|  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | 0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.11. 0x0040 CSIC ISP1 Input0 Select Register(Default Value:0x0000\_0004)

| Offset :0x0040 |            |             | Register Name: CSIC_ISP1_INPUT0_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x4         | ISP1 Input0 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.12. 0x0044 CSIC ISP1 Input1 Select Register(Default Value:0x0000\_0005)

| Offset :0x0044 | Register Name: CSIC_ISP1_INPUT1_SEL_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0  | R/W        | 0x5         | ISP1 Input1 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.13. 0x0048 CSIC ISP1 Input2 Select Register(Default Value:0x0000\_0006)

| Offset: 0x0048 |            |             | Register Name: CSIC_ISP1_INPUT2_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x6         | ISP1 Input2 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

**8.1.6.14. 0x004C CSIC ISP1 Input3 Select Register(Default Value:0x0000\_0007)**

| Offset :0x004C |            |             | Register Name: CSIC_ISP1_INPUT3_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x7         | ISP1 Input3 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

**8.1.6.15. 0x0050 CSIC ISP2 Input0 Select Register(Default Value:0x0000\_0008)**

| Offset :0x0050 |            |             | Register Name: CSIC_ISP2_INPUT0_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x8         | ISP2 Input0 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1 |

|  |  |  |                                                              |
|--|--|--|--------------------------------------------------------------|
|  |  |  | 1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|--|--------------------------------------------------------------|

#### 8.1.6.16. 0x0054 CSIC ISP2 Input1 Select Register(Default Value:0x0000\_0009)

| Offset :0x0054 |            |             | Register Name: CSIC_ISP2_INPUT1_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x9         | ISP2 Input1 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.17. 0x0058 CSIC ISP2 Input2 Select Register(Default Value:0x0000\_000A)

| Offset :0x0058 |            |             | Register Name: CSIC_ISP2_INPUT2_SEL_REG                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0xa         | ISP2 Input2 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1 |

|  |  |  |                                                                                                                                                                                              |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.18. 0x005C CSIC ISP2 Input3 Select Register(Default Value:0x0000\_000B)

| Offset :0x005C |            |             | Register Name: CSIC_ISP2_INPUT3_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0xb         | ISP2 Input3 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.19. 0x0060 CSIC ISP3 Input0 Select Register(Default Value:0x0000\_000C)

| Offset :0x0060 |            |             | Register Name: CSIC_ISP3_INPUT0_SEL_REG                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0xC         | ISP3 Input0 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1 |

|  |  |  |                                                                                                                                                                                                                                                                                                                              |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.20. 0x0064 CSIC ISP3 Input1 Select Register(Default Value:0x0000\_000D)

| Offset :0x0064 |            |             | Register Name: CSIC_ISP3_INPUT1_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0xD         | ISP3 Input1 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.21. 0x0068 CSIC ISP3 Input2 Select Register(Default Value:0x0000\_000e)

| Offset :0x0068 |            |             | Register Name: CSIC_ISP3_INPUT2_SEL_REG                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:4           | /          | /           | /                                                                                  |
| 3:0            | R/W        | 0xE         | ISP3 Input2 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1 |

|  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | 0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.22. 0x006C CSIC ISP3 Input3 Select Register(Default Value:0x0000\_000F)

| Offset :0x006C |            |             | Register Name: CSIC_ISP3_INPUT3_SEL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0xF         | ISP3 Input3 Select<br>0000: input from Parser0 CH0<br>0001: input from Parser0 CH1<br>0010: input from Parser0 CH2<br>0011: input from Parser0 CH3<br>0100: input from Parser1 CH0<br>0101: input from Parser1 CH1<br>0110: input from Parser1 CH2<br>0111: input from Parser1 CH3<br>1000: input from Parser2 CH0<br>1001: input from Parser2 CH1<br>1010: input from Parser2 CH2<br>1011: input from Parser2 CH3<br>1100: input from Parser3 CH0<br>1101: input from Parser3 CH1<br>1110: input from Parser3 CH2<br>1111: input from Parser3 CH3 |

#### 8.1.6.23. 0x0070 CSIC ISP Bridge Buffer Maxuse Counter Clear Register(Default Value:0x0000\_0000)

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

|      |     |     |                                                          |
|------|-----|-----|----------------------------------------------------------|
| 31:6 | /   | /   | /                                                        |
| 5    | R/W | 0x0 | ISP1_BRG1_BUF_MAXUSE_CNT_CLR<br>0: no effect<br>1: clear |
| 4    | R/W | 0x0 | ISP1_BRG0_BUF_MAXUSE_CNT_CLR<br>0: no effect<br>1: clear |
| 3:2  | /   | /   | /                                                        |
| 1    | R/W | 0x0 | ISPO_BRG1_BUF_MAXUSE_CNT_CLR<br>0: no effect<br>1: clear |
| 0    | R/W | 0x0 | ISPO_BRG0_BUF_MAXUSE_CNT_CLR<br>0: no effect<br>1: clear |

#### 8.1.6.24. 0x0074 CSIC ISPO Bridge Buffer Maxuse Counter Register(Default Value:0x0000\_0000)

| Offset :0x0074 |            |             | Register Name: CSIC_ISPO_BRG_BUF_MAXUSE_CNT_REG |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:16          | RO         | 0x0         | ISPO_BRG1_BUF_MAXUSE_CNT                        |
| 15:0           | RO         | 0x0         | ISPO_BRG0_BUF_MAXUSE_CNT                        |

#### 8.1.6.25. 0x007C CSIC ISP1 Bridge Buffer Maxuse Counter Register(Default Value:0x0000\_0000)

| Offset :0x007C |            |             | Register Name: CSIC_ISP1_BRG_BUF_MAXUSE_CNT_REG |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:16          | RO         | 0x0         | ISP1_BRG1_BUF_MAXUSE_CNT                        |
| 15:0           | RO         | 0x0         | ISP1_BRG0_BUF_MAXUSE_CNT                        |

#### 8.1.6.26. 0x0084 CSIC ISPO Bridge Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset :0x0084 |            |             | Register Name: CSIC_ISPO_BRG_INT_EN_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:25          | /          | /           | /                                                                                                       |
| 24             | R/W        | 0x0         | ISPO_BRG0_S2F_LW_MISMTCH_INT_EN<br>Picture Line Width Mismatch detect in ISPO Bridge0 Slow to Fast Side |
| 23:17          | /          | /           | /                                                                                                       |
| 16             | R/W        | 0x0         | ISPO_BRG0_F2S_LW_MISMTCH_INT_EN<br>Picture Line Width Mismatch detect in ISPO Bridge0 Fast to Slow Side |
| 15:9           | /          | /           | /                                                                                                       |

|     |     |     |                                                                          |
|-----|-----|-----|--------------------------------------------------------------------------|
| 8   | R/W | 0x0 | ISPO_BRGO_BUF_OV_INT_EN<br>ISPO Bridge0 Buffer overflow interrupt enable |
| 7:1 | /   | /   | /                                                                        |
| 0   | R/W | 0x0 | ISPO_BRGO_RS_INT_EN<br>ISPO Bridge0 Read clock too slow interrupt enable |

#### 8.1.6.27. 0x0088 CSIC ISP1 Bridge Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset :0x0088 |            |             | Register Name: CSIC_ISP1_BRG_INT_EN_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:25          | /          | /           | /                                                                                                       |
| 24             | R/W        | 0x0         | ISP1_BRGO_S2F_LW_MISMTCH_INT_EN<br>Picture Line Width Mismatch detect in ISP1 Bridge0 Slow to Fast Side |
| 23:17          | /          | /           | /                                                                                                       |
| 16             | R/W        | 0x0         | ISP1_BRGO_F2S_LW_MISMTCH_INT_EN<br>Picture Line Width Mismatch detect in ISP1 Bridge0 Fast to Slow Side |
| 15:9           | /          | /           | /                                                                                                       |
| 8              | R/W        | 0x0         | ISP1_BRGO_BUF_OV_INT_EN<br>ISP1 Bridge0 Buffer overflow interrupt enable                                |
| 7:1            | /          | /           | /                                                                                                       |
| 0              | R/W        | 0x0         | ISP1_BRGO_RS_INT_EN<br>ISP1 Bridge0 Read clock too slow interrupt enable                                |

#### 8.1.6.28. 0x008C CSIC ISPO Bridge Interrupt Pending Register(Default Value:0x0000\_0000)

| Offset :0x008C |            |             | Register Name: CSIC_ISPO_BRG_INT_PD_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:25          | /          | /           | /                                                                                                       |
| 24             | R/W1C      | 0x0         | ISPO_BRGO_S2F_LW_MISMTCH_INT_PD<br>Picture Line Width Mismatch detect in ISPO Bridge0 Slow to Fast Side |
| 23:17          | /          | /           | /                                                                                                       |
| 16             | R/W1C      | 0x0         | ISPO_BRGO_F2S_LW_MISMTCH_INT_PD<br>Picture Line Width Mismatch detect in ISPO Bridge0 Fast to Slow Side |
| 15:9           | /          | /           | /                                                                                                       |
| 8              | R/W1C      | 0x0         | ISPO_BRGO_BUF_OV_INT_PD<br>ISPO Bridge0 Buffer overflow interrupt pending                               |
| 7:1            | /          | /           | /                                                                                                       |
| 0              | R/W1C      | 0x0         | ISPO_BRGO_RS_INT_PD<br>ISPO Bridge0 Read clock too slow interrupt pending                               |

**8.1.6.29. 0x0090 CSIC ISP1 Bridge Interrupt Pending Register(Default Value:0x0000\_0000)**

| Offset :0x0090 |            |             | Register Name: CSIC_ISP1_BRG_INT_PD_REG                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:25          | /          | /           | /                                                                                                       |
| 24             | R/W1C      | 0x0         | ISP1_BRG0_S2F_LW_MISMTCH_INT_PD<br>Picture Line Width Mismatch detect in ISP1 Bridge0 Slow to Fast Side |
| 23:17          | /          | /           | /                                                                                                       |
| 16             | R/W1C      | 0x0         | ISP1_BRG0_F2S_LW_MISMTCH_INT_PD<br>Picture Line Width Mismatch detect in ISP1 Bridge0 Fast to Slow Side |
| 15:9           | /          | /           | /                                                                                                       |
| 8              | R/W1C      | 0x0         | ISP1_BRG0_BUF_OV_INT_PD<br>ISP1 Bridge0 Buffer overflow interrupt pending                               |
| 7:1            | /          | /           | /                                                                                                       |
| 0              | R/W1C      | 0x0         | ISP1_BRG0_RS_INT_PD<br>ISP1 Bridge0 Read clock too slow interrupt pending                               |

**8.1.6.30. 0x00A0 CSIC DMA0 Input Select Register(Default Value:0x0000\_0000)**

| Offset :0x00A0 |            |             | Register Name: CSIC_DMA0_INPUT_SEL_REG                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                             |
| 3:0            | R/W        | 0x0         | DMA0 Input Select<br>0000: input from ISPO CH0<br>0001: input from ISPO CH1<br>0010: input from ISPO CH2<br>0011: input from ISPO CH3<br>0100: input from ISP1 CH0<br>0101: input from ISP1 CH1<br>0110: input from ISP1 CH2<br>0111: input from ISP1 CH3<br>Others: Reserved |

**8.1.6.31. 0x00A4 CSIC DMA1 Input Select Register(Default Value:0x0000\_0000)**

| Offset :0x00A4 |            |             | Register Name: CSIC_DMA1_INPUT_SEL_REG                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:4           | /          | /           | /                                                                                                        |
| 3:0            | R/W        | 0x0         | DMA1 Input Select<br>0000: input from ISPO CH0<br>0001: input from ISPO CH1<br>0010: input from ISPO CH2 |

|  |  |  |                                                                                                                                                                   |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0011: input from ISP0 CH3<br>0100: input from ISP1 CH0<br>0101: input from ISP1 CH1<br>0110: input from ISP1 CH2<br>0111: input from ISP1 CH3<br>Others: Reserved |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.6.32. 0x00A8 CSIC DMA2 Input Select Register(Default Value:0x0000\_0000)

| Offset :0x00A8 |            |             | Register Name: CSIC_DMA2_INPUT_SEL_REG                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                             |
| 3:0            | R/W        | 0x0         | DMA2 Input Select<br>0000: input from ISP0 CH0<br>0001: input from ISP0 CH1<br>0010: input from ISP0 CH2<br>0011: input from ISP0 CH3<br>0100: input from ISP1 CH0<br>0101: input from ISP1 CH1<br>0110: input from ISP1 CH2<br>0111: input from ISP1 CH3<br>Others: Reserved |

#### 8.1.6.33. 0x00AC CSIC DMA3 Input Select Register(Default Value:0x0000\_0000)

| Offset :0x00AC |            |             | Register Name: CSIC_DMA3_INPUT_SEL_REG                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                             |
| 3:0            | R/W        | 0x0         | DMA3 Input Select<br>0000: input from ISP0 CH0<br>0001: input from ISP0 CH1<br>0010: input from ISP0 CH2<br>0011: input from ISP0 CH3<br>0100: input from ISP1 CH0<br>0101: input from ISP1 CH1<br>0110: input from ISP1 CH2<br>0111: input from ISP1 CH3<br>Others: Reserved |

#### 8.1.6.34. 0x00DC CSIC BIST CS Register(Default Value:0x0000\_0000)

| Offset :0x00DC | Register Name: CSIC_BIST_CS_REG |
|----------------|---------------------------------|
|----------------|---------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                      |
|------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | /          | /           | /                                                                                                                                                                                                                                                                                |
| 2:0  | R/W        | 0x0         | BIST_CS<br>000: Set when BK0 or ISPO_BRIDGE0 memory bist<br>001: Set when BK1 or ISPO_BRIDGE1 memory bist<br>010: Set when BK2 or ISPO_BRIDGE2 memory bist<br>011: Set when BK3 or ISPO_BRIDGE3 memory bist<br>100: Set when BK4 or ISP1_BRIDGE0 memory bist<br>Others: Reserved |

#### 8.1.6.35. 0x00E0 CSIC BIST Control Register(Default Value:0x0000\_0200)

| Offset :0x00E0 |            |             | Register Name: CSIC_BIST_CTRL_REG                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                     |
| 15             | R          | 0x0         | BIST_ERR_STA<br>BIST Error Status<br>0: NO effect<br>1: Error                                                                                         |
| 14:12          | R          | 0x0         | BIST_ERR_PAT<br>BIST Error Pattern                                                                                                                    |
| 11:10          | R          | 0x0         | BIST_ERR_CYC<br>BIST Error Cycle                                                                                                                      |
| 9              | R          | 0x1         | BIST_STOP<br>BIST STOP<br>0: running<br>1: STOP                                                                                                       |
| 8              | R          | 0x0         | BIST_BUSY<br>BIST Busy<br>0: idle<br>1: busy                                                                                                          |
| 7:5            | R/W        | 0x0         | BIST_REG_SEL<br>BIST REG Select                                                                                                                       |
| 4              | R/W        | 0x0         | BIST_ADDR_Mode_SEL<br>BIST Address Mode Select                                                                                                        |
| 3:1            | R/W        | 0x0         | BIST_WDATA_PAT<br>BIST Write Data Pattern<br>000:0x00000000<br>001:0x55555555<br>010:0x33333333<br>011:0x0FOFOFOF<br>100:0x00FF00FF<br>101:0x0000FFFF |

|   |     |     |                                                                      |
|---|-----|-----|----------------------------------------------------------------------|
|   |     |     | others: reserved                                                     |
| 0 | R/W | 0x0 | BIST_EN<br>BIST Enable<br>A positive will trigger the BIST to start. |

#### 8.1.6.36. 0x00E4 CSIC BIST Start Address Register(Default Value:0x0000\_0000)

| Offset :0x00E4 |            |             | Register Name: CSIC_BIST_START_ADDR_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:0           | R/W        | 0x0         | BIST Start Address<br>BIST Start Address. It is 32-bit aligned. |

#### 8.1.6.37. 0x00E8 CSIC BIST End Address Register(Default Value:0x0000\_0000)

| Offset :0x00E8 |            |             | Register Name: CSIC_BIST_END_ADDR_REG                       |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:0           | R/W        | 0x0         | BIST END Address<br>BIST END Address. It is 32-bit aligned. |

#### 8.1.6.38. 0x00EC CSIC BIST Data Mask Register(Default Value:0x0000\_0000)

| Offset :0x00EC |            |             | Register Name: CSIC_BIST_DATA_MASK_REG                 |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:0           | R/W        | 0x0         | BIST_DATA_MASK<br>BIST Data Mask<br>0:Unmask<br>1:Mask |

#### 8.1.6.39. 0x00F0 CSIC MBUS REQ MAX Register(Default Value:0x000F\_0F0F)

| Offset: 0x00F0 |            |             | Register Name: CSIC_MBUS_REQ_MAX_REG                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:21          | /          | /           | /                                                                                                  |
| 20:16          | R/W        | 0x0f        | MISP_MEM_REQ_MAX                                                                                   |
| 15:13          | /          | /           | /                                                                                                  |
| 12:8           | R/W        | 0x0f        | MCSI_MEM_1_REQ_MAX                                                                                 |
| 7:5            | /          | /           | /                                                                                                  |
| 4:0            | R/W        | 0x0f        | MCSI_MEM_REQ_MAX<br>Maximum of request commands for the master granted in MCSI_MEM arbiter is N+1. |

#### 8.1.6.40. 0x0100 CSIC Multi-Frame Mode Register(Default Value:0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: CSIC_MULF_MOD_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:24          | R          | 0x0         | MULF_STATUS                      |
| 23:16          | /          | /           | /                                |
| 15:8           | R/W        | 0x0         | MULF_CS                          |
| 7:1            | /          | /           | /                                |
| 0              | R/W        | 0x0         | MULF_EN                          |

#### 8.1.6.41. 0x0104 CSIC Multi-Frame Interrupt Register (Default Value:0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: CSIC_MULF_INT_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:18          | /          | /           | /                                |
| 17             | R/W1C      | 0x0         | MULF_ERR_PD                      |
| 16             | R/W1C      | 0x0         | MULF_DONE_PD                     |
| 15:2           | /          | /           | /                                |
| 1              | R/W        | 0x0         | MULF_ERR_EN                      |
| 0              | R/W        | 0x0         | MULF_DONE_EN                     |

#### 8.1.6.42. 0x01F0 CSIC Feature List Register(Default Value:0x2211\_4400)

| Offset: 0x01F0 |            |             | Register Name: CSIC_FEATURE_REG                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:28          | R          | 0x2         | VER_SMALL_PARSER_NUM<br>Only can be read when version register read enable is on. |
| 27:24          | R          | 0x2         | MCSI_NUM<br>Only can be read when version register read enable is on.             |
| 23:20          | R          | 0x1         | NCSI_NUM<br>Only can be read when version register read enable is on.             |
| 19:16          | R          | 0x1         | ISP_NUM<br>Only can be read when version register read enable is on.              |
| 15:12          | R          | 0x4         | VIPP_NUM<br>Only can be read when version register read enable is on.             |
| 11:8           | R          | 0x4         | DMA_NUM<br>Only can be read when version register read enable is on.              |
| 7:0            | /          | /           | /                                                                                 |

### 8.1.7. Parser Register Description

#### 8.1.7.1. 0x0000 Parser Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: PRS_EN_REG                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31             | R/W        | 0x0         | MCSIC_EN<br>0: Reset and disable the MCSIC module<br>1: Enable the MCSIC module                                                                       |
| 30:3           | /          | /           | /                                                                                                                                                     |
| 2              | R/W        | 0x0         | PRS_CH_MODE<br>0: Parser output channel 0~3 corresponding from input channel 0~3<br>1: Parser output channel 0~3 all from input channel 0(MIPI SEHDR) |
| 1              | R/W        | 0x0         | PRS_MODE<br>0: NCSI<br>1: MCSI                                                                                                                        |
| 0              | R/W        | 0x0         | PRS_EN<br>0: Reset and disable the parser module<br>1: Enable the parser module                                                                       |

#### 8.1.7.2. 0x0008 Parser MCSIC Interface Configuration Register(Default Value:0x0000\_0080)

| Offset: 0x0008 |            |             | Register Name: PRS_MCSI_IF_CFG_REG                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | YUV420_LINE_ORDER<br>0: YUV420 input in Y-YC-Y-YC Line Order<br>1: YUV420 input in YC-Y-YC-Y Line Order                                                                                                                                |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                      |
| 7:6            | R/W        | 0x2         | INPUT_SEQ<br>Input data sequence, only valid for YUV422 and YUV420 input format.<br><br>All data interleaved in one channel:<br>00: YUYV<br>01: YVYU<br>10: UYVY<br>11: VYUY<br><br>Y and UV in separated channel:<br>x0: UV<br>x1: VU |
| 5              | R/W        | 0x0         | OUTPUT_MODE<br>0: field mode<br>1: frame mode                                                                                                                                                                                          |
| 4:0            | /          | /           | /                                                                                                                                                                                                                                      |

**8.1.7.3. 0x000C Parser Capture Register(Default Value:0x0000\_0000)**

| Offset: 0x000C |            |             | Register Name: PRS_CAP_REG                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |
| 29:26          | R/W        | 0x0         | <p>CH3_FPS_DS<br/>Fps down sample<br/>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p>              |
| 25             | R/W        | 0x0         | <p>CH3_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 3.<br/>0: Disable video capture<br/>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.<br/>1: Enable video capture<br/>The CSI starts capturing image data at the start of the next frame.</p> |
| 24             | RC/W       | 0x0         | <p>CH3_SCAP_ON<br/>Still capture control: Capture a single still image frame on channel 3.<br/>0: Disable still capture<br/>1: Enable still capture<br/>The CSI module starts capturing image data at the start of the next frame.<br/>The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                     |
| 13:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |
| 21:18          | R/W        | 0x0         | <p>CH2_FPS_DS<br/>Fps down sample<br/>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p>              |
| 17             | R/W        | 0x0         | <p>CH2_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 2.<br/>0: Disable video capture<br/>If video capture is in progress, the CSI stops capturing image data at the end</p>                                                                                                                                                                                        |

|       |      |     |                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |      |     | <p>of the current frame, and all of the current frame data is written to output FIFO.</p> <p>1: Enable video capture</p> <p>The CSI starts capturing image data at the start of the next frame.</p>                                                                                                                                                                                                                   |
| 16    | RC/W | 0x0 | <p>CH2_SCAP_ON</p> <p>Still capture control: Capture a single still image frame on channel 2.</p> <p>0: Disable still capture</p> <p>1: Enable still capture</p> <p>The CSI module starts capturing image data at the start of the next frame.</p> <p>The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                     |
| 15:14 | /    | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:10 | R/W  | 0x0 | <p>CH1_FPS_DS</p> <p>Fps down sample</p> <p>0: no down sample</p> <p>1: 1/2 fps, only receives the first frame every 2 frames</p> <p>2: 1/3 fps, only receives the first frame every 3 frames</p> <p>3: 1/4 fps, only receives the first frame every 4 frames</p> <p>4: 1/5 fps, only receives the first frame every 4 frames</p> <p>.....</p> <p>15: 1/16 fps, only receives the first frame every 16 frames</p>     |
| 9     | R/W  | 0x0 | <p>CH1_VCAP_ON</p> <p>Video capture control: Capture the video image data stream on channel 1.</p> <p>0: Disable video capture</p> <p>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.</p> <p>1: Enable video capture</p> <p>The CSI starts capturing image data at the start of the next frame.</p> |
| 8     | RC/W | 0x0 | <p>CH1_SCAP_ON</p> <p>Still capture control: Capture a single still image frame on channel 1.</p> <p>0: Disable still capture</p> <p>1: Enable still capture</p> <p>The CSI module starts capturing image data at the start of the next frame.</p> <p>The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                     |
| 7:6   | /    | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5:2   | R/W  | 0x0 | <p>CH0_FPS_DS</p> <p>Fps down sample</p> <p>0: no down sample</p> <p>1: 1/2 fps, only receives the first frame every 2 frames</p> <p>2: 1/3 fps, only receives the first frame every 3 frames</p> <p>3: 1/4 fps, only receives the first frame every 4 frames</p> <p>4: 1/5 fps, only receives the first frame every 4 frames</p> <p>.....</p>                                                                        |

|   |      |     |                                                                                                                                                                                                                                                                                                                                                                                                        |
|---|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |     | 15: 1/16 fps, only receives the first frame every 16 frames                                                                                                                                                                                                                                                                                                                                            |
| 1 | R/W  | 0x0 | <p>CH0_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 0.<br/>0: Disable video capture<br/>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.<br/>1: Enable video capture<br/>The CSI starts capturing image data at the start of the next frame.</p> |
| 0 | RC/W | 0x0 | <p>CH0_SCAP_ON<br/>Still capture control: Capture a single still image frame on channel 0.<br/>0: Disable still capture.<br/>1: Enable still capture<br/>The CSI module starts capturing image data at the start of the next frame.<br/>The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                    |

#### 8.1.7.4. 0x0024 Parser Channel\_0 Input Format Register(Default Value:0x0000\_0003)

| Offset: 0x0024 |            |             | Register Name: PRS_CH0_INFMT_REG                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:4           | /          | /           | /                                                                                                                                                        |
| 3:0            | R/W        | 0x3         | <p>INPUT_FMT<br/>Input data format<br/>0000: RAW stream<br/>0001: reserved<br/>0010: reserved<br/>0011: YUV422<br/>0100: YUV420<br/>Others: reserved</p> |

#### 8.1.7.5. 0x0028 Parser Channel\_0 Output Horizontal Size Register(Default Value:0x0500\_0000)

| Offset: 0x0028 |            |             | Register Name: PRS_CH0_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

#### 8.1.7.6. 0x002C Parser Channel\_0 Output Vertical Size Register(Default Value:0x02D0\_0000)

| Offset: 0x002C |            |             | Register Name: PRS_CH0_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2D0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. Data is valid from this line. |

#### 8.1.7.7. 0x003C Parser Channel\_0 Input Parameter0 Register(Default Value:0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: PRS_CH0_INPUT_PARA0_REG      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |

#### 8.1.7.8. 0x0034 Parser Channel\_0 Input Parameter1 Register(Default Value:0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: PRS_CH0_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

#### 8.1.7.9. 0x0038 Parser Channel\_0 Input Parameter2 Register(Default Value:0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: PRS_CH0_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

**8.1.7.10. 0x003C Parser Channel\_0 Input Parameter3 Register(Default Value:0x0000\_0000)**

| Offset: 0x003C |            |             | Register Name: PRS_CH0_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

**8.1.7.11. 0x0040 Parser Channel\_0 Interrupt Enable Register(Default Value:0x0000\_0000)**

| Offset: 0x0040 |            |             | Register Name: PRS_CH0_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0:disable<br>1:enable                                                                             |
| 0              | R/W        | 0x0         | INPUT_PARAO_INT_EN<br>0:disable<br>1:enable                                                                             |

**8.1.7.12. 0x0044 Parser Channel\_0 Interrupt Status Register(Default Value:0x0000\_0000)**

| Offset: 0x0044 |            |             | Register Name: PRS_CH0_INT_STA_REG                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:3           | /          | /           | /                                                                                                                                                                              |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                      |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag set to 1. Write 1 to clear. |

**8.1.7.13. 0x0048 Parser Channel\_0 Line Time Register(Default Value:0x0000\_0000)**

| Offset: 0x0048 | Register Name: PRS_CH0_LINE_TIME_REG |
|----------------|--------------------------------------|
|----------------|--------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                         |
|-------|------------|-------------|-------------------------------------------------------------------------------------|
| 31:16 | RO         | 0x0         | PRS_CHO_HBLK_TIME<br>Time of H Blanking when vsync valid, unit is csi_top_clk cycle |
| 15:0  | RO         | 0x0         | PRS_CHO_HSYN_TIME<br>Time of H SYNC when vsync valid, unit is csi_top_clk cycle     |

#### 8.1.7.14. 0x0124 Parser Channel\_1 Input Format Register(Default Value:0x0000\_0003)

| Offset: 0x0124 |            |             | Register Name: PRS_CH1_INFMT_REG                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved<br>0011: YUV422<br>0100: YUV420<br>Others: reserved |

#### 8.1.7.15. 0x0128 Parser Channel\_1 Output Horizontal Size Register(Default Value:0x0500\_0000)

| Offset: 0x0128 |            |             | Register Name: PRS_CH1_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

#### 8.1.7.16. 0x012C Parser Channel\_1 Output Vertical Size Register(Default Value:0x02D0\_0000)

| Offset: 0x012C |            |             | Register Name: PRS_CH1_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. Data is valid from this line. |

**8.1.7.17. 0x0130 Parser Channel\_1 Input Parameter0 Register(Default Value:0x0000\_0000)**

| Offset: 0x0130 |            |             | Register Name: PRS_CH1_INPUT_PARA0_REG      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |

**8.1.7.18. 0x0134 Parser Channel\_1 Input Parameter1 Register(Default Value:0x0000\_0000)**

| Offset: 0x0134 |            |             | Register Name: PRS_CH1_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

**8.1.7.19. 0x0138 Parser Channel\_1 Input Parameter2 Register(Default Value:0x0000\_0000)**

| Offset: 0x0138 |            |             | Register Name: PRS_CH1_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

**8.1.7.20. 0x013C Parser Channel\_1 Input Parameter3 Register(Default Value:0x0000\_0000)**

| Offset: 0x013C |            |             | Register Name: PRS_CH1_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 8.1.7.21. 0x0140 Parser Channel\_1 Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0140 |            |             | Register Name: PRS_CH1_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0:disable<br>1:enable                                                                             |
| 0              | R/W        | 0x0         | INPUT_PARA0_INT_EN<br>0:disable<br>1:enable                                                                             |

#### 8.1.7.22. 0x0144 Parser Channel\_1 Interrupt Status Register(Default Value:0x0000\_0000)

| Offset: 0x0144 |            |             | Register Name: PRS_CH1_INT_STA_REG                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31:3           | /          | /           | /                                                                                                                                                                               |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                       |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag is set to 1. Write 1 to clear.                                                                     |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register,parser input parameter2 register or parser input parameter3 register update,this flag is set to 1. Write 1 to clear. |

#### 8.1.7.23. 0x0148 Parser Channel\_1 Line Time Register(Default Value:0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: PRS_CH1_LINE_TIME_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:16          | RO         | 0x0         | PRS_CH1_HBLK_TIME<br>Time of H Blanking when vsync valid, unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH1_HSYN_TIME<br>Time of H SYNC when vsync valid, unit is csi_top_clk cycle     |

**8.1.7.24. 0x0224 Parser Channel\_2 Input Format Register(Default Value:0x0000\_0003)**

| Offset: 0x0224 |            |             | Register Name: PRS_CH2_INFMT_REG                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:4           | /          | /           | /                                                                                                                                                        |
| 3:0            | R/W        | 0x3         | <p>INPUT_FMT<br/>Input data format<br/>0000: RAW stream<br/>0001: reserved<br/>0010: reserved<br/>0011: YUV422<br/>0100: YUV420<br/>Others: reserved</p> |

**8.1.7.25. 0x0228 Parser Channel\_2 Output Horizontal Size Register(Default Value:0x0500\_0000)**

| Offset: 0x0228 |            |             | Register Name: PRS_CH2_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

**8.1.7.26. 0x022C Parser Channel\_2 Output Vertical Size Register(Default Value:0x02D0\_0000)**

| Offset: 0x022C |            |             | Register Name: PRS_CH2_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2D0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. Data is valid from this line. |

**8.1.7.27. 0x0230 Parser Channel\_2 Input Parameter0 Register(Default Value:0x0000\_0000)**

| Offset: 0x0230 |            |             | Register Name: PRS_CH2_INPUT_PARA0_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:1           | /          | /           | /                                      |

|   |   |     |                                             |
|---|---|-----|---------------------------------------------|
| 0 | R | 0x0 | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |
|---|---|-----|---------------------------------------------|

#### 8.1.7.28. 0x0234 Parser Channel\_2 Input Parameter1 Register(Default Value:0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: PRS_CH2_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

#### 8.1.7.29. 0x0238 Parser Channel\_2 Input Parameter2 Register(Default Value:0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: PRS_CH2_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

#### 8.1.7.30. 0x023C Parser Channel\_2 Input Parameter3 Register(Default Value:0x0000\_0000)

| Offset: 0x023C |            |             | Register Name: PRS_CH2_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 8.1.7.31. 0x0240 Parser Channel\_2 Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: PRS_CH2_INT_EN_REG             |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:3           | /          | /           | /                                             |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error |

|   |     |     |                                                                        |
|---|-----|-----|------------------------------------------------------------------------|
|   |     |     | Indicates error has been detected for writing data to a wrong channel. |
| 1 | R/W | 0x0 | INPUT_PARA1_INT_EN<br>0:disable<br>1:enable                            |
| 0 | R/W | 0x0 | INPUT_PARA0_INT_EN<br>0:disable<br>1:enable                            |

#### 8.1.7.32. 0x0244 Parser Channel\_2 Interrupt Status Register(Default Value:0x0000\_0000)

| Offset: 0x0244 |            |             | Register Name: PRS_CH2_INT_STA_REG                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:3           | /          | /           | /                                                                                                                                                                              |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                      |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag set to 1. Write 1 to clear. |

#### 8.1.7.33. 0x0248 Parser Channel\_2 Line Time Register(Default Value:0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: PRS_CH2_LINE_TIME_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:16          | RO         | 0x0         | PRS_CH2_HBLK_TIME<br>Time of H Blanking when vsync valid, unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH2_HSYN_TIME<br>Time of H SYNC when vsync valid, unit is csi_top_clk cycle     |

#### 8.1.7.34. 0x0324 Parser Channel\_3 Input Format Register(Default Value:0x0000\_0003)

| Offset: 0x0324 |            |             | Register Name: PRS_CH3_INFMT_REG                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:4           | /          | /           | /                                                                                      |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved |

|  |  |  |                                                  |
|--|--|--|--------------------------------------------------|
|  |  |  | 0011: YUV422<br>0100: YUV420<br>Others: reserved |
|--|--|--|--------------------------------------------------|

#### 8.1.7.35. 0x0328 Parser Channel\_3 Output Horizontal Size Register(Default Value:0x0500\_0000)

| Offset: 0x0328 |            |             | Register Name: PRS_CH3_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

#### 8.1.7.36. 0x032C Parser Channel\_3 Output Vertical Size Register(Default Value:0x02D0\_0000)

| Offset: 0x032C |            |             | Register Name: PRS_CH3_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. data is valid from this line. |

#### 8.1.7.37. 0x0330 Parser Channel\_3 Input Parameter0 Register(Default Value:0x0000\_0000)

| Offset: 0x0330 |            |             | Register Name: PRS_CH3_INPUT_PARA0_REG      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |

#### 8.1.7.38. Parser Channel\_3 Input Parameter1 Register(Default Value:0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: PRS_CH3_INPUT_PARA1_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |

|       |   |     |                                         |
|-------|---|-----|-----------------------------------------|
| 29:16 | R | 0x0 | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14 | / | /   | /                                       |
| 13:0  | R | 0x0 | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

#### 8.1.7.39. 0x0338 Parser Channel\_3 Input Parameter2 Register(Default Value:0x0000\_0000)

| Offset: 0x0338 |            |             | Register Name: PRS_CH3_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

#### 8.1.7.40. 0x033C Parser Channel\_3 Input Parameter3 Register(Default Value:0x0000\_0000)

| Offset: 0x033C |            |             | Register Name: PRS_CH3_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 8.1.7.41. 0x0340 Parser Channel\_3 Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: PRS_CH3_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT PARA1_INT_EN<br>0:disable<br>1:enable                                                                             |
| 0              | R/W        | 0x0         | INPUT PARA0_INT_EN<br>0:disable<br>1:enable                                                                             |

#### 8.1.7.42. 0x0344 Parser Channel\_3 Interrupt Status Register(Default Value:0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: PRS_CH3_INT_STA_REG                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:3           | /          | /           | /                                                                                                                                                                              |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                      |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag set to 1. Write 1 to clear. |

#### 8.1.7.43. 0x0348 Parser Channel\_3 Line Time Register(Default Value:0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: PRS_CH3_LINE_TIME_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:16          | RO         | 0x0         | PRS_CH3_HBLK_TIME<br>Time of H Blanking when vsync valid, unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH3_HSYN_TIME<br>Time of H SYNC when vsync valid, unit is csi_top_clk cycle     |

#### 8.1.7.44. 0x0520 Parser CSIC SYNC EN Register(Default Value:0x0000\_0000)

| Offset :0x0520 |            |             | Register Name: CSIC_SYNC_EN_REG                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 31:20          | /          | /           | /                                                                                                                                                                      |
| 19:16          | R/W        | 0x0         | Input vsync singal source select<br>0000: Vsync signals all from 1 parser<br>0001: Vsync signals from 2 parser<br>0010: Vsync signals from 4 parser<br>others:reserved |
| 15:12          | /          | /           | /                                                                                                                                                                      |
| 11:8           | R/W        | 0x0         | Generate sync singal benchmark select<br>Bit8: USE VSYNC_Input0<br>Bit9: USE VSYNC_Input1<br>Bit10: USE VSYNC_Input2<br>Bit11: USE VSYNC_Input3<br>Set 1 to use input  |
| 7:4            | R/W        | 0x0         | Parser input vsync singal enable in sync mode                                                                                                                          |

|   |     |     |                                                                                                               |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------|
|   |     |     | Bit4: VSYNC_Input0<br>Bit5: VSYNC_Input1<br>Bit6: VSYNC_Input2<br>Bit7: VSYNC_Input3<br>Set 1 to enable input |
| 3 | /   | /   | /                                                                                                             |
| 2 | R/W | 0x0 | Parser sent sync singal via by<br>0: FSYNC0<br>1: FSYNC1                                                      |
| 1 | R/W | 0x0 | Parser sync singal source select<br>0: From outside<br>1: Generate by self                                    |
| 0 | R/W | 0x0 | Enable Parser sent sync singal<br>0: Disable<br>1: Enable                                                     |

#### 8.1.7.45. 0x0524 Parser CSIC SYNC CFG Register(Default Value:0x0000\_0000)

| Offset :0x0524 |            |             | Register Name: CSIC_PULSE_CFG_REG                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:16          | R/W        | 0x0         | PUL_WID<br>Sync signal pulse width<br>$N \cdot T_{24M}$ ,<br>$N \cdot T_{24M} \geq 4 \cdot T_{pclk}$ |
| 15:0           | R/W        | 0x0         | SYNC_DISTANCE<br>The interval of two sync signal                                                     |

#### 8.1.7.46. 0x0528 Parser CSIC VS WAIT N Register(Default Value:0x0000\_0000)

| Offset :0x0528 |            |             | Register Name: CSIC_SYNC_WAIT_N_REG                                |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:0           | R/W        | 0x0         | VS_WAIT_N<br>When multi-channel vsync all come, the max wait time. |

#### 8.1.7.47. 0x052C Parser CSIC VS WAIT M Register(Default Value:0x0000\_0000)

| Offset :0x052C |            |             | Register Name: CSIC_SYNC_WAIT_M_REG                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31:0           | R/W        | 0x0         | VS_WAIT_M<br>When in multi-channel mode,vsync comes at the different time,these bits indicate the max wait time. |

### 8.1.8. CSIC DMA Register Description

#### 8.1.8.1. 0x0000 CSIC DMA Enable Register(Default Value:0x7000\_0000)

| Offset:0x0000 |            |             | Register Name: CSIC_DMA_EN_REG                                                                                                                                                               |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31            | R/W        | 0x0         | VER_EN                                                                                                                                                                                       |
| 30            | R/W        | 0x1         | VFLIP_BUF_ADDR_CFG_MODE<br>Vflip buffer address set by software or calculated by hardware<br>0: hardware<br>1: software                                                                      |
| 29            | R/W        | 0x1         | BUF_LENGTH_CFG_MODE<br>Buffer length set by software or calculated by hardware<br>0: hardware<br>1: software                                                                                 |
| 28            | R/W        | 0x1         | FLIP_SIZE_CFG_MODE<br>FLIP SIZE set by software or calculated by hardware<br>0: hardware<br>1: software                                                                                      |
| 27:8          | /          | /           | /                                                                                                                                                                                            |
| 7             | R/W        | 0x0         | BUF_ADDR_MODE<br>0: Buffer Address Register Mode<br>1: Buffer Address FIFO Mode(only DMA0/1 support)                                                                                         |
| 6             | R/W        | 0x0         | VI_TO_CNT_EN<br>Enable Video Input Timeout counter, add 1 when there is no effective video input in a 12M clock, clear to 0 when detecting effective video input.<br>0: disable<br>1: enable |
| 5             | R/W        | 0x0         | FRAME_CNT_EN<br>When BK_TOP_EN is enabled, this bit is set to 1, it indicates that the frame counter starts to add.<br>0: Disable<br>1: Enable                                               |
| 4             | R/W        | 0x0         | DMA_EN<br>When BK_TOP_EN is enabled, this bit is set to 1, it indicates that module works in DMA mode.<br>0: Disable<br>1: Enable                                                            |
| 3             | /          | /           | /                                                                                                                                                                                            |
| 2             | R/W        | 0x0         | CLK_CNT_SPL<br>Sampling time for clk counter per frame<br>0: Sampling clock counter every frame done<br>1: Sampling clock counter every vsync                                                |

|   |     |     |                                          |
|---|-----|-----|------------------------------------------|
| 1 | R/W | 0x0 | CLK_CNT_EN<br>clk count per frame enable |
| 0 | R/W | 0x0 | BK_TOP_EN<br>0: Disable<br>1: Enable     |

#### 8.1.8.2. 0x0004 CSIC DMA Configuration Register(Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CSIC_DMA_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:24          | R/W        | 0x0         | PAD_VAL<br>Padding value when OUTPUT_FMT is prgb888<br>0x00~0xff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21             | R/W        | 0x0         | YUV 10-bit input cut to 8-bit<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 20             | R/W        | 0x0         | YUV 10-bit store configure<br>0: YUV 10-bit stored in low 10-bit of a 16-bit word<br>1: YUV 10-bit stored in high 10-bit of a 16-bit word                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19:16          | R/W        | 0x0         | OUTPUT_FMT<br>Output data format<br>When the input format is set to RAW stream<br>0000: field-raw-8<br>0001: field-raw-10<br>0010: field-raw-12<br>0011: reserved<br>0100: field-rgb565<br>0101: field-rgb888<br>0110: field-prgb888<br>0111: reserved<br>1000: frame-raw-8<br>1001: frame-raw-10<br>1010: frame-raw-12<br>1011: reserved<br>1100: frame-rgb565<br>1101: frame-rgb888<br>1110: frame-prgb888<br>1111: reserved<br><br>When the input format is set to YUV422<br>0000: field planar YCbCr 422<br>0001: field planar YCbCr 420<br>0010: frame planar YCbCr 420 |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | <p>0011: frame planar YCbCr 422<br/>     0100: field planar YCbCr 422 UV combined(UV sequence)<br/>     0101: field planar YCbCr 420 UV combined(UV sequence)<br/>     0110: frame planar YCbCr 420 UV combined(UV sequence)<br/>     0111: frame planar YCbCr 422 UV combined(UV sequence)<br/>     1000: filed planar YCbCr 422 UV combined(VU sequence)<br/>     1001: field planar YCbCr 420 UV combined(VU sequence)<br/>     1010: frame planar YCbCr 420 UV combined(VU sequence)<br/>     1011: frame planar YCbCr 422 UV combined(VU sequence)<br/>     1100: reserved<br/>     1101: field YCbCr 400<br/>     1110: reserved<br/>     1111: frame YCbCr 400</p> <p>When the input format is set to YUV420<br/>     0000: LBC mode output<br/>     0001: field planar YCbCr 420<br/>     0010: frame planar YCbCr 420<br/>     0011: reserved<br/>     0100: reserved<br/>     0101: field planar YCbCr 420 UV combined(UV sequence)<br/>     0110: frame planar YCbCr 420 UV combined(UV sequence)<br/>     0111~1000: reserved<br/>     1001: field planar YCbCr 420 UV combined(VU sequence)<br/>     1010: frame planar YCbCr 420 UV combined(VU sequence)<br/>     1011~1100: reserved<br/>     1101: field YCbCr 400<br/>     1110: reserved<br/>     1111: frame YCbCr 400</p> |
| 15:14 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 13    | R/W | 0x0 | <p>VFLIP_EN<br/>     Vertical flip enable<br/>     When enabled, the received data will be arranged in vertical flip.<br/>     0:Disable<br/>     1:Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12    | R/W | 0x0 | <p>HFLIP_EN<br/>     Horizontal flip enable<br/>     When enabled, the received data will be arranged in horizontal flip.<br/>     0:Disable<br/>     1:Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11:10 | R/W | 0x0 | <p>FIELD_SEL<br/>     Field selection<br/>     00: capturing with field 0<br/>     01: capturing with field 1<br/>     10: capturing with either field</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 11: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9:6 | R/W | 0x0 | <p>FPS_DS<br/>                 Fps down sample<br/>                 0: no down sample<br/>                 1: 1/2 fps, only receives the first frame every 2 frames<br/>                 2: 1/3 fps, only receives the first frame every 3 frames<br/>                 3: 1/4 fps, only receives the first frame every 4 frames<br/>                 4: 1/5 fps, only receives the first frame every 4 frames<br/>                 .....<br/>                 15: 1/16 fps, only receives the first frame every 16 frames</p> |
| 5:2 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1:0 | R/W | 0x0 | <p>MIN_SDR_WR_SIZE<br/>                 Minimum size of SDRAM block write<br/>                 00: 256 bytes (if hflip is enabled, and always selected 256 bytes)<br/>                 01: 512 bytes<br/>                 10: 1k bytes<br/>                 11: 2k bytes</p>                                                                                                                                                                                                                                                  |

#### 8.1.8.3. 0x0010 CSIC DMA Horizontal Size Register(Default Value:0x0500\_0000)

| Offset: 0x0010 |            |             | Register Name: CSIC_DMA_HSIZE_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 28:16          | R/W        | 0x500       | <p>HOR_LEN<br/>                 When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled, these bits indicate input width in FBC mode.<br/>                 When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC is disabled, these bits indicate Horizontal pixel unit length. Valid pixel of a line in DMA mode.<br/>                 When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC is enabled, these bits indicate input width in LBC mode.</p> |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12:0           | R/W        | 0x0         | <p>HOR_START<br/>                 Horizontal pixel unit start. Pixel is valid from this pixel.</p>                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 8.1.8.4. 0x0014 CSIC DMA Vertical Size Register(Default Value:0x02D0\_0000)

| Offset: 0x0014 |            |             | Register Name: CSIC_DMA_VSIZE_REG                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:29          | /          | /           | /                                                                                                     |
| 28:16          | R/W        | 0x2D0       | <p>VER_LEN<br/>                 When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled,</p> |

|       |     |     |                                                                                                                                                                                                                                                                                                                                      |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | these bits indicate Input height in FBC mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC is disabled, these bits indicate Valid line number of a frame in DMA mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC is enabled, these bits indicate Input height in LBC mode. |
| 15:13 | /   | /   | /                                                                                                                                                                                                                                                                                                                                    |
| 12:0  | R/W | 0x0 | VER_START<br>Vertical line start. Data is valid from this line.                                                                                                                                                                                                                                                                      |

#### 8.1.8.5. 0x0020 CSIC DMA FIFO 0 Output Buffer-A Address Register(Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CSIC_DMA_F0_BUFA_REG                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:0           | R/W        | 0x0         | F0_BUFA<br>When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled, these bits indicate output address of overhead data in FBC mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC_EN is disabled, these bits indicate FIFO 0 output buffer-A address in DMA mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC_EN is enabled, these bits indicate the output buffer address in LBC mode. |

#### 8.1.8.6. 0x0024 CSIC DMA FIFO 0 Output Buffer-A Address Result Register(Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CSIC_DMA_F0_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F0_BUFA_RESULT<br>Indicate the final F0_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

#### 8.1.8.7. 0x0028 CSIC DMA FIFO 1 Output Buffer-A Address Register(Default Value:0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CSIC_DMA_F1_BUFA_REG                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | F1_BUFA<br>When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled, these bits indicate output address of compressed data in FBC mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, these bits indicate FIFO 1 output buffer-A address in DMA mode. |

#### 8.1.8.8. 0x002C CSIC DMA FIFO 1 Output Buffer-A Address Result Register(Default Value:0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: CSIC_DMA_F1_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F1_BUFA_RESULT<br>Indicate the final F1_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

#### 8.1.8.9. 0x0030 CSIC DMA FIFO 2 Output Buffer-A Address Register(Default Value:0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CSIC_DMA_F2_BUFA_REG        |
|----------------|------------|-------------|--------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                |
| 31:0           | R/W        | 0x0         | F2_BUFA<br>FIFO 2 output buffer-A address. |

#### 8.1.8.10. 0x0034 CSIC DMA FIFO 2 Output Buffer-A Address Result Register(Default Value:0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: CSIC_DMA_F2_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F2_BUFA_RESULT<br>Indicate the final F2_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

#### 8.1.8.11. 0x0038 CSIC DMA Buffer Length Register(Default Value:0x0280\_0500)

| Offset: 0x0038 |            |             | Register Name: CSIC_DMA_BUF_LEN_REG                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:30          | /          | /           | /                                                                                                                                                                                                                         |
| 29:16          | R/W        | 0x280       | BUF_LEN_C<br>DMA_MODE: Buffer length of chroma C in a line. Unit is byte.<br>LBC_MODE: Buffer length Stride of luminance Y in ONLY Y line. Unit is byte.<br>Only Readable when BUF_LENGTH_CFG_MODE is set 0.              |
| 15:14          | /          | /           | /                                                                                                                                                                                                                         |
| 13:0           | R/W        | 0x500       | BUF_LEN<br>DMA_MODE: Buffer length of luminance Y in a line. Unit is byte.<br>LBC_MODE: Buffer length Stride of luminance Y and chroma C in YC line.<br>Unit is byte.<br>Only Readable when BUF_LENGTH_CFG_MODE is set 0. |

**8.1.8.12. 0x003C CSIC DMA Flip Size Register(Default Value:0x02D0\_0500)**

| Offset: 0x003C |            |             | Register Name: CSIC_DMA_FLIP_SIZE_REG                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:29          | /          | /           | /                                                                                                                                       |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Vertical line number when in VFLIP mode. Unit is line.<br>Only Readable when FLIP_SIZE_CFG_MODE is set 0.                    |
| 15:14          | /          | /           | /                                                                                                                                       |
| 13:0           | R/W        | 0x500       | VALID_LEN<br>Valid components of a line when in HFLIP mode. Unit is pixel component.<br>Only Readable when FLIP_SIZE_CFG_MODE is set 0. |

**8.1.8.13. 0x0040 CSIC DMA Video Input Timeout Threshold0 Register(Default Value:0x0000\_0000)**

| Offset: 0x0040 |            |             | Register Name: CSIC_DMA_VI_TO_TH0_REG                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:0           | R/W        | 0x0         | Video Input Timeout Threshold0<br>Set VIDEO_INPUT_TO_INT_PD when VI Counter reaches TH0 after VI_TO_CNT_EN is set , the time unit is a 12M clock period. |

**8.1.8.14. 0x0044 CSIC DMA Video Input Timeout Threshold1 Register(Default Value:0x0000\_0000)**

| Offset: 0x0044 |            |             | Register Name: CSIC_DMA_VI_TO_TH1_REG                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | Video Input Timeout Threshold1<br>Set VIDEO_INPUT_TO_INT_PD when VI Counter reaches TH1 after getting the first frame has been input, the time unit is a 12M clock period. |

**8.1.8.15. 0x0048 CSIC DMA Video Input Timeout Counter Value Register(Default Value:0x0000\_0000)**

| Offset: 0x0048 |            |             | Register Name: CSIC_DMA_VI_TO_CNT_VAL_REG                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31:0           | R          | 0x0         | Video Input Timeout Counter Value<br>Indicate the current value of Video Input Timeout Counter |

**8.1.8.16. 0x004C CSIC DMA Capture Status Register(Default Value:0x0000\_0000)**

| Offset: 0x004C |            |             | Register Name: CSIC_DMA_CAP_STA_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |

|      |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|---|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | / | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2    | R | 0x0 | <b>FIELD_STA</b><br>The status of the received field<br>0: Field 0<br>1: Field 1                                                                                                                                                                                                                                                                                                                                                 |
| 1    | R | 0x0 | <b>VCAP_STA</b><br>Video capture in progress<br>Indicates the CSI is capturing video image data (multiple frames). The bit is set at the start of the first frame after enabling video capture. When software disables video capture, it clears itself after the last pixel of the current frame is captured.                                                                                                                    |
| 0    | R | 0x0 | <b>SCAP_STA</b><br>Still capture in progress<br>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end. |

#### 8.1.8.17. 0x0050 CSIC DMA Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: CSIC_DMA_INT_EN_REG                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                              |
| 15             | R/W        | 0x0         | <b>FRM_LOST_INT_EN</b><br>Set an INT when frame starts with empty Buffer Address FIFO, only use in BUF Address FIFO MODE.                                      |
| 14             | R/W        | 0x0         | <b>STORED_FRM_CNT_INT_EN</b><br>Set an INT when the value of CSIC_DMA_STORED_FRM_CNT reaches CSIC_DMA_STORED_FRM_THRESHOLD, only use in BUF Address FIFO MODE. |
| 13             | R/W        | 0x0         | <b>BUF_ADDR_FIFO_INT_EN</b><br>Set an INT when content in BUF Address FIFO less than CSIC_DMA_BUFA_FIFO_THRESHOLD, only use in BUF Address FIFO MODE.          |
| 12             | R/W        | 0x0         | <b>VIDEO_INPUT_TO_INT_EN</b><br>Set an INT when no video input exceeds the setting threshold time                                                              |
| 11             | R/W        | 0x0         | <b>CLR_FRAME_CNT_INT_EN</b><br>Set a INT when Clear Frame cnt.                                                                                                 |
| 10             | R/W        | 0x0         | <b>SENT_SYNC_INT_EN</b><br>Set a INT when sent a SYNC signal.                                                                                                  |
| 9              | R/W        | 0x0         | <b>FBC_DATA_WRDDR_FULL_EN</b><br>Error flag of FBC_DATA_WRDDR_FULL.                                                                                            |
| 8              | R/W        | 0x0         | <b>FBC_OVHD_WRDDR_FULL_EN</b>                                                                                                                                  |

|   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Error flag of FBC_OVHD_WRDDR_FULL.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7 | R/W | 0x0 | <p>VS_INT_EN<br/>vsync flag<br/>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, changing the buffer address could only effect next frame</p>                                                                                                                                                                                                                                                        |
| 6 | R/W | 0x0 | <p>HB_OF_INT_EN<br/>Hblank FIFO overflow<br/>The bit is set when 3 FIFOs still overflow after the hblank.</p>                                                                                                                                                                                                                                                                                                                                                              |
| 5 | R/W | 0x0 | <p>LC_INT_EN<br/>Line counter flag<br/>The bit is set when the specific line has been written to dram every frame. The line number is set in the line counter register.</p>                                                                                                                                                                                                                                                                                                |
| 4 | R/W | 0x0 | <p>FIFO2_OF_INT_EN<br/>FIFO 2 overflow<br/>The bit is set when the FIFO 2 became overflow.</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 3 | R/W | 0x0 | <p>FIFO1_OF_INT_EN<br/>FIFO 1 overflow<br/>The bit is set when the FIFO 1 became overflow.</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 2 | R/W | 0x0 | <p>FIFO0_OF_INT_EN<br/>FIFO 0 overflow<br/>The bit is set when the FIFO 0 became overflow.</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 1 | R/W | 0x0 | <p>FD_INT_EN<br/>Frame done<br/>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is written to buffer as long as video capture remains enabled.</p>                                                                                                                                                                                                                        |
| 0 | R/W | 0x0 | <p>CD_INT_EN<br/>Capture done<br/>Indicates the CSI has completed capturing the image data.<br/>For still capture, the bit is set when one frame data has been written to buffer.<br/>For video capture, the bit is set when the last frame has been written to buffer after video capture has been disabled.<br/>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end.</p> |

#### 8.1.8.18. 0x0054 CSIC DMA Interrupt Status Register(Default Value:0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: CSIC_DMA_INT_STA_REG                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:16          | /          | /           | /                                                                                                   |
| 15             | R/W1C      | 0x0         | <p>FRM_LOST_INT_PD<br/>Set an INT when frame starts with empty Buffer Address FIFO, only use in</p> |

|    |       |     |                                                                                                                                                        |
|----|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | BUF Address FIFO MODE                                                                                                                                  |
| 14 | R/W1C | 0x0 | STORED_FRM_CNT_INT_PD<br>Set an INT when the value of CSIC_DMA_STORED_FRM_CNT reaches CSIC_DMA_STORED_FRM_THRESHOLD, only use in BUF Address FIFO MODE |
| 13 | R/W1C | 0x0 | BUF_ADDR_FIFO_INT_PD<br>Set an INT when content in BUF Address FIFO less than CSIC_DMA_BUFA_FIFO_THRESHOLD, only use in BUF Address FIFO MODE          |
| 12 | R/W1C | 0x0 | VIDEO_INPUT_TO_INT_PD<br>Set an INT pending when no video input exceeds the setting threshold time                                                     |
| 11 | R/W1C | 0x0 | CLR_FRAME_CNT_INT<br>Set a INT when clear Frame cnt.                                                                                                   |
| 10 | R/W1C | 0x0 | SENT_SYNC_INT<br>Set a INT when sent a SYNC signal.                                                                                                    |
| 9  | R/W1C | 0x0 | FBC_DATA_WRDDR_FULL_PD<br>Error flag of FBC_DATA_WRDDR_FULL.                                                                                           |
| 8  | R/W1C | 0x0 | FBC_OVHD_WRDDR_FULL_PD<br>Error flag of FBC_OVHD_WRDDR_FULL.                                                                                           |
| 7  | R/W1C | 0x0 | VS_PD<br>vsync flag                                                                                                                                    |
| 6  | R/W1C | 0x0 | HB_OF_PD<br>Hblank FIFO overflow                                                                                                                       |
| 5  | R/W1C | 0x0 | LC_PD<br>Line counter flag                                                                                                                             |
| 4  | R/W1C | 0x0 | FIFO2_OF_PD<br>FIFO 2 overflow                                                                                                                         |
| 3  | R/W1C | 0x0 | FIFO1_OF_PD<br>FIFO 1 overflow                                                                                                                         |
| 2  | R/W1C | 0x0 | FIFO0_OF_PD<br>FIFO 0 overflow                                                                                                                         |
| 1  | R/W1C | 0x0 | FD_PD<br>Frame done                                                                                                                                    |
| 0  | R/W1C | 0x0 | CD_PD<br>Capture done                                                                                                                                  |

#### 8.1.8.19. 0x0058 CSIC DMA Line Counter Register(Default Value:0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: CSIC_DMA_LINE_CNT_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:13          | /          | /           | /                                                                                                                            |
| 12:0           | R/W        | 0x0         | LINE_CNT_NUM<br>The LINE_CNT_NUM value is set by user,when internal line counter reach the set value, the LC_PD will be set. |

#### 8.1.8.20. 0x005C CSIC DMA Frame Counter Register(Default Value:0x0001\_0000)

| Offset: 0x005C |            |             | Register Name: CSIC_DMA_FRM_CNT_REG                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 31             | R/W1C      | 0x0         | FRM_CNT_CLR<br>When the bit set to 1, Frame cnt is cleared to 0                                                                                                                               |
| 30:16          | R/W        | 0x1         | PCLK_DMA_CLR_DISTANCE<br>Frame cnt clear cycle<br>$N \cdot T_{SYNC}$                                                                                                                          |
| 15:0           | R          | 0x0         | FRM_CNT<br>Counter value of frame. When frame done comes, the internal counter value add 1, and when the reg full, it is cleared to 0.<br>When parser sent a sync signal, it is cleared to 0. |

#### 8.1.8.21. 0x0060 CSIC DMA Frame Clock Counter Register(Default Value:0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: CSIC_DMA_FRM_CLK_CNT_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 23:0           | R          | 0x0         | FRM_CLK_CNT<br>Counter value between every frame. For instant hardware frame rate statics.<br>The internal counter is added by one every 12 MHz clock cycle. When frame done or vsync comes, the internal counter value is sampled to FRM_CLK_CNT, and cleared to 0. |

#### 8.1.8.22. 0x0064 CSIC DMA Accumulated and Internal Clock Counter Register(Default Value:0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: CSIC_DMA_ACC_ITNL_CLK_CNT_REG                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                   |
| 31:24          | R/WC       | 0x0         | ACC_CLK_CNT<br>The accumulated value of FRM_CLK_CNT for software frame rate statics.<br>Every interrupt of frame is done, the software checks this accumulated value and clears it to 0. If the ACC_CLK_CNT is larger than 1, the software has lost frame.<br><br>When frame done or vsync comes, ACC_CLK_CNT = ACC_CLK_CNT + 1, and cleared to 0 when writing this register. |
| 23:0           | R          | 0x0         | ITNL_CLK_CNT<br>The instant value of internal frame clock counter.<br>When frame done interrupt comes, the software can query this counter for judging whether it is the time for updating the double buffer address                                                                                                                                                          |

|  |  |  |            |
|--|--|--|------------|
|  |  |  | registers. |
|--|--|--|------------|

#### 8.1.8.23. 0x0068 CSIC DMA FIFO Statistic Register(Default Value:0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: CSIC_DMA_FIFO_STAT_REG                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:30          | /          | /           | /                                                                                                                          |
| 29:16          | R          | 0x0         | Line Index<br>Indicates the line index in current vsync.                                                                   |
| 15:13          | /          | /           | /                                                                                                                          |
| 12:0           | R          | 0x0         | FIFO_FRM_MAX<br>Indicates the maximum depth of FIFO being occupied for whole frame.<br>Update at every vsync or framedone. |

#### 8.1.8.24. 0x006C CSIC DMA FIFO Threshold Register(Default Value:0x0000\_0400)

| Offset: 0x006C |            |             | Register Name: CSIC_DMA_FIFO_THRS_REG                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:12          | /          | /           | /                                                                                           |
| 11:0           | R/W        | 0x400       | FIFO_THRS<br>When FIFO occupied memory exceed the threshold, dram frequency can not change. |

#### 8.1.8.25. 0x0070 CSIC DMA PCLK Statistic Register(Default Value:0x0000\_7FFF)

| Offset: 0x0070 |            |             | Register Name: CSIC_DMA_PCLK_STAT_REG                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31             | /          | /           | /                                                                                                                      |
| 30:16          | R          | 0x0         | PCLK_CNT_LINE_MAX<br>Indicates maximum pixel clock counter value for each line.<br>Update at every vsync or framedone. |
| 15             | /          | /           | /                                                                                                                      |
| 14:0           | R          | 0x7FFF      | PCLK_CNT_LINE_MIN<br>Indicates minimum pixel clock counter value for each line.<br>Update at every vsync or framedone. |

#### 8.1.8.26. 0x0080 CSIC DMA BUF Address FIFO0 Entry Register(Default Value:0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO0_ENTRY_REG |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |

|      |     |     |                                                                                                                                       |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W | 0x0 | CSIC_DMA_BUF_ADDR_FIFO0_ENTRY<br>FIFO Entry of Buffer Address FIFO0 for input frames to be stored, only used in Buffer Addr FIFO Mode |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|

#### 8.1.8.27. 0x0084 CSIC DMA BUF Address FIFO1 Entry Register(Default Value:0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO1_ENTRY_REG                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:0           | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO1_ENTRY<br>FIFO Entry of Buffer Address FIFO1 for input frames to be stored, only used in Buffer Addr FIFO Mode |

#### 8.1.8.28. 0x0088 CSIC DMA BUF Address FIFO2 Entry Register(Default Value:0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO2_ENTRY_REG                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:0           | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO2_ENTRY<br>FIFO Entry of Buffer Address FIFO2 for input frames to be stored, only used in Buffer Addr FIFO Mode |

#### 8.1.8.29. 0x008C CSIC DMA BUF Threshold Register(Default Value:0x0020\_0000)

| Offset: 0x008C |            |             | Register Name: CSIC_DMA_BUF_TH_REG                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 31:21          | /          | /           | /                                                                                                                                                         |
| 21:16          | R/W        | 0x20        | CSIC_DMA_STORED_FRM_THRESHOLD<br>when stored frame counter value reaches the threshold , counter is cleared to 0 , only used in Buffer Addr FIFO Mode.    |
| 15:6           | /          | /           | /                                                                                                                                                         |
| 5:0            | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO_THRESHOLD<br>when content in Buffer Address FIFO less than the threshold, an interrupt is set, only used in Buffer Addr FIFO Mode. |

#### 8.1.8.30. 0x0090 CSIC DMA BUF Address FIFO Content Register(Default Value:0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO_CON_REG                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:22          | /          | /           | /                                                                                                         |
| 21:16          | RO         | 0x0         | CSIC_DMA_BUF_ADDR_FIFO2_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO2, only used in |

|       |    |     |                                                                                                                                  |
|-------|----|-----|----------------------------------------------------------------------------------------------------------------------------------|
|       |    |     | Buffer Addr FIFO Mode.                                                                                                           |
| 15:14 | /  | /   | /                                                                                                                                |
| 13:8  | RO | 0x0 | CSIC_DMA_BUF_ADDR_FIFO1_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO1, only used in Buffer Addr FIFO Mode. |
| 7:6   | /  | /   | /                                                                                                                                |
| 5:0   | RO | 0x0 | CSIC_DMA_BUF_ADDR_FIFO0_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO0, only used in Buffer Addr FIFO Mode. |

#### 8.1.8.31. 0x0094 CSIC DMA Stored Frame Counter Register(Default Value:0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: CSIC_DMA_STORED_FRM_CNT_REG                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:8           | /          | /           | /                                                                                                                                                                                           |
| 7:0            | RO         | 0x0         | CSIC_DMA_STORED_FRM_CNT<br>Indicates value of stored frames counter, when counter value reaches CSIC_DMA_STORED_FRM_THRESHOLD, counter is cleared to 0, only used in Buffer Addr FIFO Mode. |

#### 8.1.8.32. 0x0100 CSIC LBC Configure Register(Default Value:0x8F30\_0008)

| Offset: 0x0100 |            |             | Register Name: CSIC_LBC_CONFIG_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31             | R/W        | 0x1         | Whether lossy compress enable      |
| 30:28          | /          | /           | /                                  |
| 27             | R/W        | 0x1         | Glb enable                         |
| 26             | R/W        | 0x1         | Dts enable                         |
| 25             | R/W        | 0x1         | Ots enable                         |
| 24             | R/W        | 0x1         | Msq enable                         |
| 23:22          | /          | /           | /                                  |
| 21             | R/W        | 0x1         | Updata advanture enable            |
| 20:16          | R/W        | 0x10        | Updata advanture ratio             |
| 15:4           | /          | /           | /                                  |
| 3              | R/W        | 0x1         | Limit qp enable                    |
| 2:0            | R/W        | 0x0         | Limit qp min                       |

#### 8.1.8.33. 0x0104 CSIC LBC Line Target Bit0 Register(Default Value:0x0000\_2400)

| Offset: 0x0104 |            |             | Register Name: CSIC_LBC_LINE_TAR_BIT0_REG |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |

|       |     |        |                                       |
|-------|-----|--------|---------------------------------------|
| 31:20 | /   | /      | /                                     |
| 19:0  | R/W | 0x2400 | Compress target bit for the even line |

#### 8.1.8.34. 0x0108 CSIC LBC Line Target Bit1 Register(Default Value:0x0000\_3600)

| Offset: 0x0108 |            |             | Register Name: CSIC_LBC_LINE_TAR_BIT1_REG |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:20          | /          | /           | /                                         |
| 19:0           | R/W        | 0x3600      | Compress target bit for the odd line      |

#### 8.1.8.35. 0x010C CSIC LBC RC ADV Register(Default Value:0x1010\_1010)

| Offset: 0x010C |            |             | Register Name: CSIC_LBC_RC_ADV_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:24          | R/W        | 0x10        | Rate control advanture 3           |
| 23:16          | R/W        | 0x10        | Rate control advanture 2           |
| 15:8           | R/W        | 0x10        | Rate control advanture 1           |
| 7:0            | R/W        | 0x10        | Rate control advanture 0           |

#### 8.1.8.36. 0x0110 CSIC LBC MB MIN Register(Default Value:0x006E\_0037)

| Offset: 0x0110 |            |             | Register Name: CSIC_LBC_MB_MIN_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:25          | /          | /           | /                                  |
| 24:16          | R/W        | 0x6E        | Macro block min bits1              |
| 15:9           | /          | /           | /                                  |
| 8:0            | R/W        | 0x37        | Macro block min bits0              |

#### 8.1.8.37. 0x01F4 CSIC DMA Feature List Register(Default Value:0x0000\_0000)

| Offset: 0x01F4 |            |             | Register Name: CSIC_FEATURE_REG                            |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:2           | /          | /           | /                                                          |
| 1              | R          | 0x0         | DMA0_EMBEDDED_LBC<br>0: No Embedded LBC<br>1: Embedded LBC |
| 0              | R          | 0x0         | DMA0_EMBEDDED_FBC<br>0: No Embedded DMA<br>1: Embedded FBC |

## Contents

|                                                     |     |
|-----------------------------------------------------|-----|
| Chapter 9 Audio.....                                | 580 |
| 9.1. I2S/PCM.....                                   | 580 |
| 9.1.1. Overview .....                               | 580 |
| 9.1.2. Block Diagram .....                          | 580 |
| 9.1.3. Operations and Functional Descriptions ..... | 581 |
| 9.1.4. Programming Guidelines.....                  | 586 |
| 9.1.5. Register List .....                          | 588 |
| 9.1.6. Register Description .....                   | 589 |
| 9.2. DMIC.....                                      | 618 |
| 9.2.1. Overview .....                               | 618 |
| 9.2.2. Block Diagram .....                          | 618 |
| 9.2.3. Operations and Functional Descriptions ..... | 618 |
| 9.2.4. Register List .....                          | 620 |
| 9.2.5. Register Description .....                   | 621 |
| 9.3. OWA .....                                      | 632 |
| 9.3.1. Overview .....                               | 632 |
| 9.3.2. Block Diagram .....                          | 632 |
| 9.3.3. Operations and Functional Descriptions ..... | 633 |
| 9.3.4. Register List .....                          | 637 |
| 9.3.5. Register Description .....                   | 637 |
| 9.4. Audio Codec .....                              | 645 |
| 9.4.1. Overview .....                               | 645 |
| 9.4.2. Block Diagram .....                          | 645 |
| 9.4.3. Operations and Functional Descriptions ..... | 646 |
| 9.4.4. Programming Guidelines.....                  | 656 |
| 9.4.5. Register List .....                          | 656 |
| 9.4.6. Register Description .....                   | 659 |

## Figures

|                                                           |     |
|-----------------------------------------------------------|-----|
| Figure 9- 1. I2S/PCM Interface System Block Diagram ..... | 581 |
| Figure 9- 2. I2S Standard Mode Timing.....                | 582 |
| Figure 9- 3. Left-Justified Mode Timing .....             | 583 |
| Figure 9- 4. Right-Justified Mode Timing .....            | 583 |
| Figure 9- 5. PCM Long Frame Mode Timing.....              | 583 |
| Figure 9- 6. PCM Short Frame Mode Timing.....             | 584 |
| Figure 9- 7. 16 Channels Mapping Configuration .....      | 584 |
| Figure 9- 8. I2S/PCM Operation Flow .....                 | 585 |
| Figure 9- 9. DMIC Block Diagram .....                     | 618 |
| Figure 9- 10. DMIC Operation Mode.....                    | 619 |
| Figure 9- 11. OWA Block Diagram.....                      | 632 |
| Figure 9- 12. OWA Biphase-Mark Code .....                 | 634 |
| Figure 9- 13. OWA Sub-Frame Format.....                   | 634 |
| Figure 9- 14. OWA Frame/Block Format.....                 | 635 |
| Figure 9- 15. OWA Operation Flow .....                    | 636 |
| Figure 9- 16. Audio Codec Block Diagram.....              | 646 |
| Figure 9- 17. Audio Codec Clock Diagram.....              | 648 |
| Figure 9- 18. Audio Codec Digital Part Reset System.....  | 649 |
| Figure 9- 19. Audio Codec Analog Part Reset System.....   | 649 |
| Figure 9- 20. Audio Codec Data Path Diagram.....          | 650 |
| Figure 9- 21. Headphone Output Application .....          | 651 |
| Figure 9- 22. External Accessory Detection .....          | 652 |
| Figure 9- 23. Audio Codec Interrupt System.....           | 652 |
| Figure 9- 24. DAP Data Flow .....                         | 653 |
| Figure 9- 25. HPF Function .....                          | 653 |
| Figure 9- 26. DRC Block Diagram.....                      | 653 |
| Figure 9- 27. DRC Static Curve Parameters.....            | 654 |
| Figure 9- 28. Energy Filter Structure .....               | 654 |
| Figure 9- 29. Gain Smooth Filter .....                    | 655 |

## Tables

---

|                                           |     |
|-------------------------------------------|-----|
| Table 9- 1. I2S/PCM External Signals..... | 581 |
| Table 9- 2. I2S/PCM Clock Sources.....    | 582 |
| Table 9- 3. DIN Slot ID and Encoder ..... | 584 |
| Table 9- 4. DMIC External Signals.....    | 618 |
| Table 9- 5. DMIC Clock Sources.....       | 619 |
| Table 9- 6. OWA External Signals .....    | 633 |
| Table 9- 7. OWA Clock Sources .....       | 633 |
| Table 9- 8. Biphase-Mark Encoder .....    | 634 |
| Table 9- 9. Preamble Codes .....          | 635 |

Confidential

# Chapter 9 Audio

## 9.1. I2S/PCM

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

- Compliant with standard Philips Inter-IC sound (I2S) bus specification
- Compliant with Left-justified, Right-justified, PCM mode, and TDM (Time Division Multiplexing) format
- Full-duplex synchronous work mode
- Master/slave mode
- Adjustable interface voltage
- Clock up to 24.576 MHz
- Adjustable audio sample resolution from 8-bit to 32-bit
- Up to 16 channel( $f_s = 48\text{ kHz}$ ) which has adjustable width from 8-bit to 32-bit
- Sample rate from 8 kHz to 384 kHz(CHAN = 2)
- Supports 8-bit u-law and 8-bit A-law companded sample
- One 128 depth x 32-bit width TXFIFO for data transmit, one 64 depth x 32-bit width RXFIFO for data receive
- Programmable PCM frame width: 1 BCLK width (short frame) and 2 BCLKs width (long frame)
- Programmable FIFO thresholds
- Interrupt and DMA support
- Supports loop back mode for test

### 9.1.2. Block Diagram

The block diagram of I2S/PCM interface is shown as follows.



Figure 9-1. I2S/PCM Interface System Block Diagram

### 9.1.3. Operations and Functional Descriptions

#### 9.1.3.1. External Signals

Table 9-1 describes the external signals of I2S/PCM interface. LRCK and BCLK are bidirectional I/O, when I2S/PCM interface is configured as Master device, LRCK and BCLK is output pin; when I2S/PCM interface is configured as slave device, LRCK and BCLK is input pin. MCLK is an output pin for external device. DOUT is always the serial data output pin, and DIN is the serial data input pin. For information about General Purpose I/O port, see Port Controller.

Table 9-1. I2S/PCM External Signals

| Signal         | Description                                | Type |
|----------------|--------------------------------------------|------|
| I2S0_MCLK      | I2S0 Master Clock                          | O    |
| I2S0_LRCK      | I2S0/PCM0 Sample Rate Clock/Sync           | I/O  |
| I2S0_BCLK      | I2S0/PCM0 Sample Rate Clock                | I/O  |
| I2S0_DOUT[1:0] | I2S0/PCM0 Serial Data Output Channel [1:0] | O    |
| I2S0_DIN[1:0]  | I2S0/PCM0 Serial Data Input Channel [1:0]  | I    |
| I2S1_MCLK      | I2S1 Master Clock                          | O    |
| I2S1_LRCK      | I2S1/PCM1 Sample Rate Clock/Sync           | I/O  |
| I2S1_BCLK      | I2S1/PCM1 Sample 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    |
| I2S2_MCLK      | I2S2 Master Clock                          | O    |
| I2S2_LRCK      | I2S2/PCM2 Sample Rate Clock/Sync           | I/O  |
| I2S2_BCLK      | I2S2/PCM2 Sample Rate Clock                | I/O  |
| I2S2_DOUT[1:0] | I2S2/PCM2 Serial Data Output Channel [1:0] | O    |
| I2S2_DIN[1:0]  | I2S2/PCM2 Serial Data Input Channel [1:0]  | I    |
| I2S3_MCLK      | I2S3 Master Clock                          | O    |

|                |                                            |     |
|----------------|--------------------------------------------|-----|
| I2S3_LRCK      | I2S3/PCM3 Sample Rate Clock/Sync           | I/O |
| I2S3_BCLK      | I2S3/PCM3 Sample 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   |

### 9.1.3.2. Clock Sources

Table 9-2 describes the clock sources for I2S/PCM. Users can see **Chapter 3.3.CCU** for clock setting, configuration and gating information.

**Table 9- 2. I2S/PCM Clock Sources**

| Clock Name    | Description                                                                                                                                             |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_AUDIO(4X) | The 98.304 MHz frequency generated by PLL_AUDIO(4X) to produce 48 kHz sample frequency.                                                                 |
| PLL_COM_AUDIO | The 90.3168 MHz frequency generated by PLL_COM_AUDIO is divided by 4 (=22.5792 MHz) and then passed to the module to produce 44.1 kHz sample frequency. |

### 9.1.3.3. Timing Diagram

The I2S/PCM supports standard I2S mode, Left-justified I2S mode, Right-justified I2S mode, PCM mode and TDM mode. Software can select any modes by setting the **I2S/PCM Control Register**. Figure 9-2 to Figure 9-6 describe the waveforms for SYNC, BCLK and DOUT, DIN.



**Figure 9- 2. I2S Standard Mode Timing**



Figure 9-3. Left-Justified Mode Timing



Figure 9-4. Right-Justified Mode Timing



Figure 9-5. PCM Long Frame Mode Timing



Figure 9- 6. PCM Short Frame Mode Timing

#### 9.1.3.4. DIN Slot Mapping

The 4-wire DIN has 64 slots, each wire DIN has 16 slots, but RX is only 16 channels valid, the relationship between slot id and encoder is as follows.

Table 9- 3. DIN Slot ID and Encoder

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| DIN0 Slot ID | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 |
| DIN1 Slot ID | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
| DIN2 Slot ID | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
| DIN3 Slot ID | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 |

There are 16 channels mapping configuration, each wire is selected four slots into RX.



Figure 9- 7. 16 Channels Mapping Configuration

### 9.1.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. These five steps are described in detail in the following sections.



Figure 9-8. I2S/PCM Operation Flow

#### (1). System Setup and I2S/PCM Initialization

The clock source for the I2S/PCM should be followed. At first you must disable the PLL\_AUDIO through the **PLL\_ENABLE** bit of **PLL\_AUDIO\_CTRL\_REG** in the CCU. The second step, you must set up the frequency of the PLL\_AUDIO in the **PLL\_AUDIO\_CTRL\_REG**. After that, you must open the I2S/PCM gating through the **I2S/PCM\_CLK\_REG** when you checkout that the LOCK bit of **PLL\_AUDIO\_CTRL\_REG** becomes to 1. At last, you must reset and open the I2S/PCM bus gating in the **I2S/PCM\_BGR\_REG**.

After the system setup, the register of I2S/PCM can be setup. At first, you should initialization 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 to it. After that, you must 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**.

#### (2). Channel Setup and DMA Setup

First, you can setup the master I2S/PCM and the slave I2S/PCM. The configuration can be referred to the protocol of I2S/PCM. Then, you can set up the translation mode, the sample resolution, the wide of slot, the channel slot number and the trigger level and so on. The setup of 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 **DMA**. In this module, you just enable the DRQ.

### (3). Enable and Disable I2S/PCM

To enable the function, you can enable TX/RX by writing the **I2S/PCM\_CTL[2:1]**. After that, you must enable I2S/PCM by writing 1 to the **Globe Enable** bit in the **I2S/PCM\_CTL**. Write 0 to the **Globe Enable** bit to disable I2S/PCM.

#### 9.1.4. Programming Guidelines

The following example assumes that the audio channels are stereo channels in I2S mode, the sampling rate is 48 kHz, the sampling precision is 16 bits. The recording and playback processes are as follows.

##### -----GPIO configuration-----

Step1: Ensure that I2S/PCM0 GPIO has power supply.

Step2: Configure GPIOB4/GPIOB5/GPIOB6/GPIOB7/GPIOB8 as Function3.

##### -----Clock configuration-----

Step1: Configure PLL\_AUDIO as 24.576 MHz, that is, set **PLL\_AUDIO Control Register** to 0xA90B1701, set **PLL\_AUDIO Pattern0 Register** to 0xC00126E9 (If PLL\_AUDIO is set as 22.5792 MHz, that is, set **PLL\_AUDIO Control Register** to 0xA90B1501, set **PLL\_AUDIO Pattern0 Register** to 0xC001288D).

Step2: Check whether **PLL\_AUDIO Control Register[PLL\_AUDIO\_LOCK]** is 0x1. If is 1, set **I2S/PCM0 Clock Register** to 0x80000000.

Step3: Write 0x1 to the bit16 of **I2S/PCM0 Bus Gating Reset Register** to dessert I2S/PCM0 reset.

Step4: Write 0x1 to the bit0 of **I2S/PCM0 Bus Gating Reset Register** to open I2S/PCM0 gating.



#### NOTE

The Step3 and Step4 is set separately.

##### -----Initialization I2S/PCM-----

Step1: Set the bit[2:0] of **I2S/PCM Control Register** to 0 to close TXEN,RXEN and GEN.

Step2: Set the bit[25:24] of **I2S/PCM FIFO Control Register** to 0x3 to clear TXFIFO and RXFIFO.

Step3: Set **I2S/PCM TX Counter Register** to 0 to clear TX counter, set **I2S/PCM RX Counter Register** to 0 to clear RX counter.

##### -----Format configuration-----

Step1: Master/slave configuration. In master mode, the bit[18:17] of **I2S/PCM RX Counter Register** is set to 0x3; in slave mode, the bit[18:17] of **I2S/PCM RX Counter Register** is set to 0.

Step2: Configure the[5:4] of **I2S/PCM Control Register** to 0x1 to set standard I2S mode, configure the bit[21:20] of **I2S/PCM TX0 Channel Select Register** to 0x1, configure the bit[21:20] of **I2S/PCM RX Channel Select Register** to 0x1.

Step3: Configure the bit[6:4] of **I2S/PCM Format Register0** to 0x3 to set sample resolution, configure the bit[2:0] of **I2S/PCM Format Register0** to 0x3 to set channel width.

Step4: Configure the bit[7:4] of **I2S/PCM Channel Configuration Register** to 0x1 to set RX channel number, configure

the bit[3:0] of **I2S/PCM Channel Configuration Register** to 0x1 to set TX channel number. Configure the bit[19:16] of **I2S/PCM TX0 Channel Select Register** to 0x1, configure the bit[1:0] of **I2S/PCM TX0 Channel Select Register** to 0x3. Configure the bit[19:16] of **I2S/PCM RX Channel Select Register** to 0x1.

Step5: Configure the bit[7:0] of **I2S/PCM TX0 Channel Mapping Register 1** to 0x10, configure the bit[5:0] of **I2S/PCM RX Channel Mapping Register 3** to 0x0, configure the bit[13:8] of **I2S/PCM RX Channel Mapping Register 3** to 0x1.

-----Clock divider configuration-----

Step1: Set MCLK divider. Configure the bit[3:0] of **I2S/PCM Clock Divide Register** to 0x1, that is, MCLK=24.576MHz. Configure the bit8 of **I2S/PCM Clock Divide Register** to 0x1 to enable MCLK.

Step2: Set BCLK divider. Configure the bit[7:4] of **I2S/PCM Clock Divide Register** to 0xF, that is, BCLK=Sample ratio\*Slot\_Width\*Slot\_Num=48K\*16\*2=1.536MHz.

Step3: Set LRCK divider. Configure the bit[17:8] of **I2S/PCM Format Register** to 0xF, that is, N-1=BCLK/Sample ratio/Slot\_Num =16,N=15.

-----DMA configuration-----

Step1: Set data width of both DMA\_SRC and DMA\_DEST to 16-bit.

Step2: Set DMA BLOCK SIZE,DMA\_SRC BLOCK SIZE and DMA\_DEST BLOCK SIZE to 8.

Step3: TX DMA configuration. Set DMA\_SRC\_DRQ\_TYPE to DRAM, set DMA\_SRC\_ADDR\_MODE to Linear Mode, set DMA\_DEST\_DRQ\_TYPE to I2S/PCM0-TX, set DMA\_DEST\_ADDR\_MODE to IO Mode, set DMA\_SRC\_ADDR to DRAM address of storing data, set DMA\_DEST\_ADDR to **I2S/PCM TXFIFO**(address: 0x05090020).

Step4: RX DMA configuration. Set DMA\_SRC\_DRQ\_TYPE to I2S/PCM0-RX, set DMA\_SRC\_ADDR\_MODE to IO Mode, set DMA\_DEST\_DRQ\_TYPE to DRAM, set DMA\_DEST\_ADDR\_MODE to Linear Mode, set DMA\_SRC\_ADDR to **I2S/PCM RXFIFO**(address: 0x05090010), set DMA\_DEST\_ADDR to DRAM address of storing data.

For more details about DMA, please see the description of DMA in section 3.9.



**NOTE**

If data is stored in SRAM, then DRAM is modified to SRAM.

-----Recording/playback/pause-----

Step1: Enable globe, set the bit0 of **I2S/PCM Control Register** to 0x1. Enable DOUT0\_EN, set the bit8 of **I2S/PCM Control Register** to 0x1.

Step2: Recording start: set the bit1 of **I2S/PCM Control Register** to 0x1, set the bit3 of **I2S/PCM DMA & Interrupt Control Register** to 0x1.

Step3: Playback start: set the bit2 of **I2S/PCM Control Register** to 0x1, set the bit7 of **I2S/PCM DMA & Interrupt Control Register** to 0x1.

Step4: Recording pause: set the bit1 of **I2S/PCM Control Register** to 0, set the bit3 of **I2S/PCM DMA & Interrupt Control Register** to 0.

Step5: Playback pause: set the bit2 of **I2S/PCM Control Register** to 0, set the bit7 of **I2S/PCM DMA & Interrupt Control Register** to 0.

### 9.1.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| I2S/PCM0    | 0x05090000   |
| I2S/PCM1    | 0x05091000   |
| I2S/PCM2    | 0x05092000   |
| I2S/PCM3    | 0x05093000   |

| 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                  |
| I2S/PCMISTA       | 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 & 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_TX0CHCFG  | 0x0034 | I2S/PCM TX0 Channel Configuration Register |
| I2S/PCM_TX1CHCFG  | 0x0038 | I2S/PCM TX1 Channel Configuration Register |
| I2S/PCM_TX2CHCFG  | 0x003C | I2S/PCM TX2 Channel Configuration Register |
| I2S/PCM_TX3CHCFG  | 0x0040 | I2S/PCM TX3 Channel Configuration 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       |

### 9.1.6. Register Description

#### 9.1.6.1. 0x0000 I2S/PCM Control Register(Default Value: 0x0006\_0000)

| Offset: 0x0000 |            |             | Register Name: I2S/PCM_CTL                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:22          | /          | /           | /                                                                                                                                                                                    |
| 21             | R/W        | 0x0         | <b>RX_SYNC_EN</b><br>Audio/I2S/DMIC RX (RXEN) Synchronize Enable<br>0: Disable<br>1: Enable                                                                                          |
| 20             | R/W        | 0x0         | <b>RX_EN_MUX</b><br>Audio RX (RXEN) Enable MUX<br>0: Disable<br>1: Enable                                                                                                            |
| 19             | /          | /           | /                                                                                                                                                                                    |
| 18             | R/W        | 0x1         | <b>BCLK_OUT</b><br>0: Input<br>1: Output                                                                                                                                             |
| 17             | R/W        | 0x1         | <b>LRCK_OUT</b><br>0: Input<br>1: Output                                                                                                                                             |
| 16:12          | /          | /           | /                                                                                                                                                                                    |
| 11             | R/W        | 0x0         | <b>DOUT3_EN</b><br>0: Disable, Hi-Z State<br>1: Enable                                                                                                                               |
| 10             | R/W        | 0x0         | <b>DOUT2_EN</b><br>0: Disable, Hi-Z State<br>1: Enable                                                                                                                               |
| 9              | R/W        | 0x0         | <b>DOUT1_EN</b><br>0: Disable, Hi-Z State<br>1: Enable                                                                                                                               |
| 8              | R/W        | 0x0         | <b>DOUT0_EN</b><br>0: Disable, Hi-Z State<br>1: Enable                                                                                                                               |
| 7              | /          | /           | /                                                                                                                                                                                    |
| 6              | R/W        | 0x0         | <b>OUT_MUTE</b><br>0: Normal Transfer<br>1: Force DOUT to output 0                                                                                                                   |
| 5:4            | R/W        | 0x0         | <b>MODE_SEL</b><br>Mode Selection<br>00: PCM Mode (offset 0: Long Frame; offset 1: Short Frame)<br>01: Left Mode (offset 0: LJ Mode; offset 1: I2S Mode)<br>10: Right-Justified Mode |

|   |     |     |                                                                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 11: Reserved                                                                                                                                           |
| 3 | R/W | 0x0 | <p>LOOP<br/>Loop Back Test<br/>0: Normal Mode<br/>1: Loop Back Test<br/>When setting to '1' , the bit indicates that the DOUT connects to the DIN.</p> |
| 2 | R/W | 0x0 | <p>TXEN<br/>Transmitter Block Enable<br/>0: Disable<br/>1: Enable</p>                                                                                  |
| 1 | R/W | 0x0 | <p>RXEN<br/>Receiver Block Enable<br/>0: Disable<br/>1: Enable</p>                                                                                     |
| 0 | R/W | 0x0 | <p>GEN<br/>Globe Enable<br/>0: Disable<br/>1: Enable</p>                                                                                               |

#### 9.1.6.2. 0x0004 I2S/PCM Format Register 0(Default Value: 0x0000\_0033)

| Offset: 0x0004 |            |             | Register Name: I2S/PCM_FMT0                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                       |
| 31             | /          | /           | /                                                                                                                                                                                                                                                                                                 |
| 30             | R/W        | 0x0         | <p>LRCK_WIDTH<br/>LRCK Width(only apply in PCM mode )<br/>0: LRCK = 1 BCLK Width (Short Frame)<br/>1: LRCK = 2 BCLK Width (Long Frame)</p>                                                                                                                                                        |
| 29:20          | /          | /           | /                                                                                                                                                                                                                                                                                                 |
| 19             | R/W        | 0x0         | <p>LRCK_POLARITY<br/>In I2S/Left-Justified/Right-Justified mode:<br/>0: Left channel when LRCK is low<br/>1: Left channel when LRCK is high<br/>In PCM mode:<br/>0: PCM LRCK asserted at the negative edge<br/>1: PCM LRCK asserted at the positive edge</p>                                      |
| 18             | /          | /           | /                                                                                                                                                                                                                                                                                                 |
| 17:8           | R/W        | 0x0         | <p>LRCK_PERIOD<br/>It is used to program the number of BCLKs per channel of sample frame.<br/>This value is interpreted as follows.<br/><b>PCM mode:</b> Number of BCLKs within (Left + Right) channel width.<br/><b>I2S/Left-Justified/Right-Justified mode:</b> Number of BCLKs within each</p> |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | individual channel width (Left or Right) .<br>For example:<br>N = 7: 8 BCLKs width<br>...<br>N = 1023: 1024 BCLKs width                                                                                                                                                                                                                                                                                                                                          |
| 7   | R/W | 0x0 | BCLK_POLARITY<br>0: Normal mode, DOUT drives data at negative edge<br>1: Invert mode, DOUT drives data at positive edge                                                                                                                                                                                                                                                                                                                                          |
| 6:4 | R/W | 0x3 | SR<br>Sample Resolution<br>000: Reserved<br>001: 8-bit<br>010: 12-bit<br>011: 16-bit<br>100: 20-bit<br>101: 24-bit<br>110: 28-bit<br>111: 32-bit                                                                                                                                                                                                                                                                                                                 |
| 3   | R/W | 0x0 | EDGE_TRANSFER<br>0: DOUT drives data and DIN sample data at the different BCLK edge<br>1: DOUT drives data and DIN sample data at the same BCLK edge<br>BCLK_POLARITY = 0, EDGE_TRANSFER = 0, DIN sample data at positive edge;<br>BCLK_POLARITY = 0, EDGE_TRANSFER = 1, DIN sample data at negative edge;<br>BCLK_POLARITY = 1, EDGE_TRANSFER = 0, DIN sample data at negative edge;<br>BCLK_POLARITY = 1, EDGE_TRANSFER = 1, DIN sample data at positive edge. |
| 2:0 | R/W | 0x3 | SW<br>Slot Width Select<br>000: Reserved<br>001: 8-bit<br>010: 12-bit<br>011: 16-bit<br>100: 20-bit<br>101: 24-bit<br>110: 28-bit<br>111: 32-bit                                                                                                                                                                                                                                                                                                                 |

#### 9.1.6.3. 0x0008 I2S/PCM Format Register 1(Default Value: 0x0000\_0030)

| Offset: 0x0008 |            | Register Name: I2S/PCM_FMT1 |             |
|----------------|------------|-----------------------------|-------------|
| Bit            | Read/Write | Default/Hex                 | Description |

|      |     |     |                                                                                                                                                                                                                        |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /   | /   | /                                                                                                                                                                                                                      |
| 7    | R/W | 0x0 | RX MLS<br>MSB/LSB First Select<br>0: MSB First<br>1: LSB First                                                                                                                                                         |
| 6    | R/W | 0x0 | TX MLS<br>MSB/LSB First Select<br>0: MSB First<br>1: LSB First                                                                                                                                                         |
| 5:4  | R/W | 0x3 | SEXT<br>Sign Extend in Slot [Sample Resolution < Slot Width]<br>00: Zeros or audio gain padding at LSB position<br>01: Sign extension at MSB position<br>10: Reserved<br>11: Transfer 0 after each sample in each Slot |
| 3:2  | R/W | 0x0 | RX_PDM<br>PCM Data Mode<br>00: Linear PCM<br>01: Reserved<br>10: 8-bit u-law<br>11: 8-bit A-law                                                                                                                        |
| 1:0  | R/W | 0x0 | TX_PDM<br>PCM Data Mode<br>00: Linear PCM<br>01: Reserved<br>10: 8-bit u-law<br>11: 8-bit A-law                                                                                                                        |

#### 9.1.6.4. 0x000C I2S/PCM Interrupt Status Register(Default Value: 0x0000\_0010)

| Offset: 0x000C |            |             | Register Name: I2S/PCMISTA                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:7           | /          | /           | /                                                                                                                                                     |
| 6              | R/W1C      | 0x0         | TXU_INT<br>TXFIFO Underrun Pending Interrupt<br>0: No pending interrupt<br>1: TXFIFO underrun pending interrupt<br>Write '1' to clear this interrupt. |
| 5              | R/W1C      | 0x0         | TXO_INT<br>TXFIFO Overrun Pending Interrupt<br>0: No pending interrupt<br>1: TXFIFO overrun pending interrupt<br>Write '1' to clear this interrupt.   |
| 4              | R          | 0x1         | TXE_INT                                                                                                                                               |

|   |       |     |                                                                                                                                                             |
|---|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | TXFIFO Empty Pending Interrupt<br>0: No pending IRQ<br>1: TXFIFO empty pending interrupt when data in TXFIFO are less than TX trigger level                 |
| 3 | /     | /   | /                                                                                                                                                           |
| 2 | R/W1C | 0x0 | RXU_INT<br>RXFIFO Underrun Pending Interrupt<br>0: No pending interrupt<br>1: RXFIFO underrun pending interrupt<br>Write '1' to clear this interrupt.       |
| 1 | R/W1C | 0x0 | RXO_INT<br>RXFIFO Overrun Pending Interrupt<br>0: No pending IRQ<br>1: RXFIFO overrun pending IRQ<br>Write '1' to clear this interrupt.                     |
| 0 | R/W   | 0x0 | RXA_INT<br>RXFIFO Data Available Pending Interrupt<br>0: No pending IRQ<br>1: Data available pending IRQ when data in RXFIFO are more than RX trigger level |

#### 9.1.6.5. 0x0010 I2S/PCM RXFIFO Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: I2S/PCM_RXFIFO                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 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. The left channel sample data is first and then the right channel sample. |

#### 9.1.6.6. 0x0014 I2S/PCM FIFO Control Register(Default Value: 0x0004\_00F0)

| Offset: 0x0014 |            |             | Register Name: I2S/PCM_FCTL                             |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31             | R/W        | 0x0         | HUB_EN<br>Audio Hub Enable<br>0 : Disable<br>1 : Enable |
| 30:26          | /          | /           | /                                                       |
| 25             | R/WAC      | 0x0         | FTX<br>Write '1' to flush TXFIFO, self clear to '0'.    |
| 24             | R/WAC      | 0x0         | FRX                                                     |

|       |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | Write '1' to flush RXFIFO, self clear to '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23:19 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18:12 | R/W | 0x40 | <p>TXTL</p> <p>TXFIFO Empty Trigger Level</p> <p>Interrupt and DMA request trigger level for TXFIFO normal condition.</p> <p>Trigger Level = TXTL</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11:10 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9:4   | R/W | 0xF  | <p>RXTL</p> <p>RXFIFO Trigger Level</p> <p>Interrupt and DMA request trigger level for RXFIFO normal condition.</p> <p>Trigger Level = RXTL + 1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3     | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2     | R/W | 0x0  | <p>TXIM</p> <p>TXFIFO Input Mode (Mode 0, 1)</p> <p>0: Valid data at the MSB of TXFIFO register</p> <p>1: Valid data at the LSB of TXFIFO register</p> <p>Example for 20-bit transmitted audio sample:</p> <p>Mode 0: TXFIFO[31:0] = {APB_WDATA[31:12], 12'h0}</p> <p>Mode 1: TXFIFO[31:0] = {APB_WDATA[19:0], 12'h0}</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1:0   | R/W | 0x0  | <p>RXOM</p> <p>RXFIFO Output Mode (Mode 0, 1, 2, 3)</p> <p>00: Expanding '0' at LSB of RXFIFO register</p> <p>01: Expanding received sample sign bit at MSB of RXFIFO register</p> <p>10: Truncating received samples at high half-word of RXFIFO register and low half-word of RXFIFO register is filled by '0'</p> <p>11: Truncating received samples at low half-word of RXFIFO register and high half-word of RXFIFO register is expanded by its sign bit</p> <p>Example for 20-bit received audio sample:</p> <p>Mode 0: APB_RDATA[31:0] = {RXFIFO[31:12], 12'h0}</p> <p>Mode 1: APB_RDATA[31:0] = {12{RXFIFO[31]}, RXFIFO[31:12]}</p> <p>Mode 2: APB_RDATA [31:0] = {RXFIFO[31:16], 16'h0}</p> <p>Mode 3: APB_RDATA[31:0] = {16{RXFIFO[31]}, RXFIFO[31:16]}</p> |

#### 9.1.6.7. 0x0018 I2S/PCM FIFO Status Register(Default Value: 0x1080\_0000)

| Offset: 0x0018 |            |             | Register Name: I2S/PCM_FSTA                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 31:29          | /          | /           | /                                                                                                                                              |
| 28             | R          | 0x1         | <p>TXE</p> <p>TXFIFO Empty</p> <p>0: No room for new sample in TXFIFO</p> <p>1: More than one room for new sample in TXFIFO (&gt;= 1 Word)</p> |
| 27:24          | /          | /           | /                                                                                                                                              |

|       |   |      |                                                                                                            |
|-------|---|------|------------------------------------------------------------------------------------------------------------|
| 23:16 | R | 0x80 | TXE_CNT<br>RXFIFO Empty Space Word Counter                                                                 |
| 15:9  | / | /    | /                                                                                                          |
| 8     | R | 0x0  | RXA<br>RXFIFO Available<br>0: No available data in RXFIFO<br>1: More than one sample in RXFIFO (>= 1 Word) |
| 7     | / | /    | /                                                                                                          |
| 6:0   | R | 0x0  | RXA_CNT<br>RXFIFO available sample word counter                                                            |

#### 9.1.6.8. 0x001C I2S/PCM DMA & Interrupt Control Register(Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: I2S/PCM_INT                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:8           | /          | /           | /                                                                                                                                                                 |
| 7              | R/W        | 0x0         | TX_DRQ<br>RXFIFO Empty DRQ Enable<br>0: Disable<br>1: Enable                                                                                                      |
| 6              | R/W        | 0x0         | TXUI_EN<br>RXFIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable                                                                                            |
| 5              | R/W        | 0x0         | TXOI_EN<br>RXFIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable<br>When setting to '1', an interrupt happens when writing new audio data if RXFIFO is full. |
| 4              | R/W        | 0x0         | TXEI_EN<br>RXFIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                                                               |
| 3              | R/W        | 0x0         | RX_DRQ<br>RXFIFO Data Available DRQ Enable<br>0: Disable<br>1: Enable<br>When setting to '1', RXFIFO DMA request line is asserted if data is available in RXFIFO. |
| 2              | R/W        | 0x0         | RXUI_EN<br>RXFIFO Underrun Interrupt Enable<br>0: Disable                                                                                                         |

|   |     |     |                                                                              |
|---|-----|-----|------------------------------------------------------------------------------|
|   |     |     | 1: Enable                                                                    |
| 1 | R/W | 0x0 | RXOI_EN<br>RXFIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable        |
| 0 | R/W | 0x0 | RXAI_EN<br>RXFIFO Data Available Interrupt Enable<br>0: Disable<br>1: Enable |

#### 9.1.6.9. 0x0020 I2S/PCM TXFIFO Register(Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: I2S/PCM_TXFIFO                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:0           | W          | 0x0         | TX_DATA<br>TX Sample<br>Transmitting left, right channel sample data should be written to this register one by one. The left channel sample data is first and then the right channel sample. |

#### 9.1.6.10. 0x0024 I2S/PCM Clock Divide Register(Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: I2S/PCM_CLKD                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                          |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                    |
| 8              | R/W        | 0x0         | MCLKO_EN<br>0: Disable MCLK Output<br>1: Enable MCLK Output<br><b>Note: Whether in slave or master mode, when this bit is set to '1', MCLK should be output.</b>                                                                                                                     |
| 7:4            | R/W        | 0x0         | BCLKDIV<br>BCLK Divide Ratio from PLL_AUDIO<br>0000: Reserved<br>0001: Divide by 1<br>0010: Divide by 2<br>0011: Divide by 4<br>0100: Divide by 6<br>0101: Divide by 8<br>0110: Divide by 12<br>0111: Divide by 16<br>1000: Divide by 24<br>1001: Divide by 32<br>1010: Divide by 48 |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 1011: Divide by 64<br>1100: Divide by 96<br>1101: Divide by 128<br>1110: Divide by 176<br>1111: Divide by 192                                                                                                                                                                                                                                                                                         |
| 3:0 | R/W | 0x0 | MCLKDIV<br>MCLK Divide Ratio from PLL_AUDIO<br>0000: Reserved<br>0001: Divide by 1<br>0010: Divide by 2<br>0011: Divide by 4<br>0100: Divide by 6<br>0101: Divide by 8<br>0110: Divide by 12<br>0111: Divide by 16<br>1000: Divide by 24<br>1001: Divide by 32<br>1010: Divide by 48<br>1011: Divide by 64<br>1100: Divide by 96<br>1101: Divide by 128<br>1110: Divide by 176<br>1111: Divide by 192 |

#### 9.1.6.11. 0x0028 I2S/PCM TX Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: I2S/PCM_TXCNT                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31:0           | R/W        | 0x0         | TX_CNT<br>TX Sample Counter<br>The audio sample number of sending into TXFIFO. When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX 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. |

#### 9.1.6.12. 0x002C I2S/PCM RX Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: I2S/PCM_RXCNT                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| 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. 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. |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 9.1.6.13. 0x0030 I2S/PCM Channel Configuration Register(Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: I2S/PCM_CHCFG                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:10          | /          | /           | /                                                                                                                                                                                                              |
| 9              | R/W        | 0x0         | <p>TX_SLOT_HIZ<br/>0: Normal mode for the last half cycle of BCLK in the slot<br/>1: Turn to Hi-Z state for the last half cycle of BCLK in the slot</p>                                                        |
| 8              | R/W        | 0x0         | <p>TX_STATE<br/>0: Transfer level 0 in non-transferring slot<br/>1: Turn to Hi-Z State (TDM) in non-transferring slot</p>                                                                                      |
| 7:4            | R/W        | 0x0         | <p>RX_SLOT_NUM<br/>RX Channel/Slot number between CPU/DMA and RXFIFO<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111:16 channels or slots</p> |
| 3:0            | R/W        | 0x0         | <p>RX_SLOT_NUM<br/>TX Channel/Slot number between CPU/DMA and TXFIFO<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111:16 channels or slots</p> |

#### 9.1.6.14. 0x0034 I2S/PCM TX0 Channel Select Register(Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: I2S/PCM_TX0CHSEL                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31:22          | /          | /           | /                                                                                                                        |
| 21:20          | R/W        | 0x0         | <p>TX0_OFFSET<br/>TX0 Offset Tune(TX0 Data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p> |

|       |     |     |                                                                                                                                                                                                                  |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16 | R/W | 0x0 | <b>TX0_CHSEL</b><br>TX0 Channel (Slot) Number Select for Each Output<br>0000: 1 channel or slot<br>...<br>0111: 8 channels or slots<br>1000: 9 channels or slots<br>...<br>1111:16 channels or slots             |
| 15:0  | R/W | 0x0 | <b>TX0_CHEN</b><br>TX0 Channel (Slot) Enable<br>The bit[15:0] refer to Slot [15:0]. When one or more Slot(s) is(are) disabled, the affected Slot(s) is(are) set to the disable state.<br>0: Disable<br>1: Enable |

#### 9.1.6.15. 0x0038 I2S/PCM TX1 Channel Select Register(Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: I2S/PCM_TX1CHSEL                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 31:22          | /          | /           | /                                                                                                                                                                                                                |
| 21:20          | R/W        | 0x0         | <b>TX1_OFFSET</b><br>TX1 Offset Tune(TX1 Data offset to LRCK)<br>0: No offset<br>n: Data is offset by n BCLKs to LRCK                                                                                            |
| 19:16          | R/W        | 0x0         | <b>TX1_CHSEL</b><br>TX1 Channel (Slot) Number Select for Each Output<br>0000: 1 channel or slot<br>...<br>0111: 8 channels or slots<br>1000: 9 channels or slots<br>...<br>1111:16 channels or slots             |
| 15:0           | R/W        | 0x0         | <b>TX1_CHEN</b><br>TX1 Channel (Slot) Enable<br>The bit[15:0] refer to Slot [15:0]. When one or more Slot(s) is(are) disabled, the affected Slot(s) is(are) set to the disable state.<br>0: Disable<br>1: Enable |

#### 9.1.6.16. 0x003C I2S/PCM TX2 Channel Select Register(Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: I2S/PCM_TX2CHSEL |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |

|       |     |     |                                                                                                                                                                                                                      |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:22 | /   | /   | /                                                                                                                                                                                                                    |
| 21:20 | R/W | 0x0 | <p>TX2_OFFSET<br/>TX2 Offset Tune(TX2 data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p>                                                                                             |
| 19:16 | R/W | 0x0 | <p>TX2_CHSEL<br/>TX2 Channel (Slot) Number Select for Each Output<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111:16 channels or slots</p>          |
| 15:0  | R/W | 0x0 | <p>TX2_CHEN<br/>TX2 Channel (Slot) Enable<br/>The bit[15:0] refer to Slot [15:0]. When one or more Slot(s) is(are) disabled, the affected Slot(s) is(are) set to the disable state.<br/>0: Disable<br/>1: Enable</p> |

#### 9.1.6.17. 0x0040 I2S/PCM TX3 Channel Select Register(Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: I2S/PCM_TX3CHSEL                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
| 31:22          | /          | /           | /                                                                                                                                                                                                                    |
| 21:20          | R/W        | 0x0         | <p>TX3_OFFSET<br/>TX3 Offset Tune(TX3 Data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p>                                                                                             |
| 19:16          | R/W        | 0x0         | <p>TX3_CHSEL<br/>TX3 Channel (Slot) Number Select for Each Output<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111:16 channels or slots</p>          |
| 15:0           | R/W        | 0x0         | <p>TX3_CHEN<br/>TX3 Channel (Slot) Enable<br/>The bit[15:0] refer to Slot [15:0]. When one or more Slot(s) is(are) disabled, the affected Slot(s) is(are) set to the disable state.<br/>0: Disable<br/>1: Enable</p> |

**9.1.6.18. 0x0044 I2S/PCM TX0 Channel Mapping Register 0(Default Value: 0x0000\_0000)**

| Offset: 0x0044 |            |             | Register Name: I2S/PCM_TX0CHMAP0                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:28          | R/W        | 0x0         | TX0_CH15_MAP<br>TX0 Channel 15 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 27:24          | R/W        | 0x0         | TX0_CH14_MAP<br>TX0 Channel 14 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 23:20          | R/W        | 0x0         | TX0_CH13_MAP<br>TX0 Channel 13 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16          | R/W        | 0x0         | TX0_CH12_MAP<br>TX0 Channel 12 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 15:12          | R/W        | 0x0         | TX0_CH11_MAP<br>TX0 Channel 11 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 11:8           | R/W        | 0x0         | TX0_CH10_MAP                                                                                                                          |

|     |     |     |                                                                                                                                     |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | TX0 Channel 10 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample               |
| 7:4 | R/W | 0x0 | TX0_CH9_MAP<br>TX0 Channel 9 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 3:0 | R/W | 0x0 | TX0_CH8_MAP<br>TX0 Channel 8 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |

#### 9.1.6.19. 0x0048 I2S/PCM TX0 Channel Mapping Register 1(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: I2S/PCM_TX0CHMAP1                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:28          | R/W        | 0x0         | TX0_CH7_MAP<br>TX0 Channel 7 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 27:24          | R/W        | 0x0         | TX0_CH6_MAP<br>TX0 Channel 6 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |

|       |     |     |                                                                                                                                     |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
| 23:20 | R/W | 0x0 | TX0_CH5_MAP<br>TX0 Channel 5 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16 | R/W | 0x0 | TX0_CH4_MAP<br>TX0 Channel 4 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 15:12 | R/W | 0x0 | TX0_CH3_MAP<br>TX0 Channel 3 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 11:8  | R/W | 0x0 | TX0_CH2_MAP<br>TX0 Channel 2 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 7:4   | R/W | 0x0 | TX0_CH1_MAP<br>TX0 Channel 1 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 3:0   | R/W | 0x0 | TX0_CH0_MAP<br>TX0 Channel 0 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample                                                 |

|  |  |  |                                              |
|--|--|--|----------------------------------------------|
|  |  |  | 1000: 9th Sample<br>...<br>1111: 16th Sample |
|--|--|--|----------------------------------------------|

#### 9.1.6.20. 0x004C I2S/PCM TX1 Channel Mapping Register 0(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: I2S/PCM_TX1CHMAP0                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:28          | R/W        | 0x0         | TX1_CH15_MAP<br>TX1 Channel 15 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 27:24          | R/W        | 0x0         | TX1_CH14_MAP<br>TX1 Channel 14 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 23:20          | R/W        | 0x0         | TX1_CH13_MAP<br>TX1 Channel 13 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16          | R/W        | 0x0         | TX1_CH12_MAP<br>TX1 Channel 12 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 15:12          | R/W        | 0x0         | TX1_CH11_MAP<br>TX1 Channel 11 Mapping<br>0000: 1st Sample<br>...                                                                     |

|      |     |     |                                                                                                                                       |
|------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample                                                                      |
| 11:8 | R/W | 0x0 | TX1_CH10_MAP<br>TX1 Channel 10 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 7:4  | R/W | 0x0 | TX1_CH9_MAP<br>TX1 Channel 9 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |
| 3:0  | R/W | 0x0 | TX1_CH8_MAP<br>TX1 Channel 8 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |

#### 9.1.6.21. 0x0050 I2S/PCM TX1 Channel Mapping Register 1(Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: I2S/PCM_TX1CHMAP1                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:28          | R/W        | 0x0         | TX1_CH7_MAP<br>TX1 Channel 7 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 27:24          | R/W        | 0x0         | TX1_CH6_MAP<br>TX1 Channel 6 Mapping<br>0000: 1st Sample                                                                            |

|       |     |     |                                                                                                                                                                        |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p>                                                                         |
| 23:20 | R/W | 0x0 | <p>TX1_CH5_MAP</p> <p>TX1 Channel 5 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 19:16 | R/W | 0x0 | <p>TX1_CH4_MAP</p> <p>TX1 Channel 4 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 15:12 | R/W | 0x0 | <p>TX1_CH3_MAP</p> <p>TX1 Channel 3 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 11:8  | R/W | 0x0 | <p>TX1_CH2_MAP</p> <p>TX1 Channel 2 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 7:4   | R/W | 0x0 | <p>TX1_CH1_MAP</p> <p>TX1 Channel 1 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |

|     |     |     |                                                                                                                                            |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | R/W | 0x0 | <b>TX1_CH0_MAP</b><br>TX1 Channel 0 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------|

#### 9.1.6.22. 0x0054 I2S/PCM TX2 Channel Mapping Register 0(Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: I2S/PCM_TX2CHMAP0                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:28          | R/W        | 0x0         | <b>TX2_CH15_MAP</b><br>TX2 Channel 15 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 27:24          | R/W        | 0x0         | <b>TX2_CH14_MAP</b><br>TX2 Channel 14 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 23:20          | R/W        | 0x0         | <b>TX2_CH13_MAP</b><br>TX2 Channel 13 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16          | R/W        | 0x0         | <b>TX2_CH12_MAP</b><br>TX2 Channel 12 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...                      |

|       |     |     |                                                                                                                                       |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1111: 16th Sample                                                                                                                     |
| 15:12 | R/W | 0x0 | TX2_CH11_MAP<br>TX2 Channel 11 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 11:8  | R/W | 0x0 | TX2_CH10_MAP<br>TX2 Channel 10 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 7:4   | R/W | 0x0 | TX2_CH9_MAP<br>TX2 Channel 9 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |
| 3:0   | R/W | 0x0 | TX2_CH8_MAP<br>TX2 Channel 8 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |

#### 9.1.6.23. 0x0058 I2S/PCM TX2 Channel Mapping Register 1(Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: I2S/PCM_TX2CHMAP1                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:28          | R/W        | 0x0         | TX2_CH7_MAP<br>TX2 Channel 7 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample |

|       |     |     |                                                                                                                                     |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | ...<br>1111: 16th Sample                                                                                                            |
| 27:24 | R/W | 0x0 | TX2_CH6_MAP<br>TX2 Channel 6 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 23:20 | R/W | 0x0 | TX2_CH5_MAP<br>TX2 Channel 5 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16 | R/W | 0x0 | TX2_CH4_MAP<br>TX2 Channel 4 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 15:12 | R/W | 0x0 | TX2_CH3_MAP<br>TX2 Channel 3 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 11:8  | R/W | 0x0 | TX2_CH2_MAP<br>TX2 Channel 2 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 7:4   | R/W | 0x0 | TX2_CH1_MAP<br>TX2 Channel 1 Mapping<br>0000: 1st Sample                                                                            |

|     |     |     |                                                                                                                                                                        |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p>                                                                         |
| 3:0 | R/W | 0x0 | <p>TX2_CH0_MAP</p> <p>TX2 Channel 0 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |

#### 9.1.6.24. 0x005C I2S/PCM TX3 Channel Mapping Register 0(Default Value: 0x0000\_0000)

| Offset: 0x005C |            |             | Register Name: I2S/PCM_TX3CHMAP0                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                              |
| 31:28          | R/W        | 0x0         | <p>TX3_CH15_MAP</p> <p>TX3 Channel 15 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 27:24          | R/W        | 0x0         | <p>TX3_CH14_MAP</p> <p>TX3 Channel 14 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th sample</p> |
| 23:20          | R/W        | 0x0         | <p>TX3_CH13_MAP</p> <p>TX3 Channel 13 Mapping</p> <p>0000: 1st Sample</p> <p>...</p> <p>0111: 8th Sample</p> <p>1000: 9th Sample</p> <p>...</p> <p>1111: 16th Sample</p> |
| 19:16          | R/W        | 0x0         | <p>TX3_CH12_MAP</p> <p>TX3 Channel 12 Mapping</p>                                                                                                                        |

|       |     |     |                                                                                                                                       |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample                                           |
| 15:12 | R/W | 0x0 | TX3_CH11_MAP<br>TX3 Channel 11 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th sample |
| 11:8  | R/W | 0x0 | TX3_CH10_MAP<br>TX3 Channel 10 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 7:4   | R/W | 0x0 | TX3_CH9_MAP<br>TX3 Channel 9 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |
| 3:0   | R/W | 0x0 | TX3_CH8_MAP<br>TX3 Channel 8 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample   |

#### 9.1.6.25. 0x0060 I2S/PCM TX3 Channel Mapping Register 1(Default Value: 0x0000\_0000)

| Offset: 0x0060 |            | Register Name: I2S/PCM_TX3CHMAP1 |             |
|----------------|------------|----------------------------------|-------------|
| Bit            | Read/Write | Default/Hex                      | Description |
| 31:28          | R/W        | 0x0                              | TX3_CH7_MAP |

|       |     |     |                                                                                                                                     |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | TX3 Channel 7 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample                |
| 27:24 | R/W | 0x0 | TX3_CH6_MAP<br>TX3 Channel 6 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 23:20 | R/W | 0x0 | TX3_CH5_MAP<br>TX3 Channel 5 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 19:16 | R/W | 0x0 | TX3_CH4_MAP<br>TX3 Channel 4 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 15:12 | R/W | 0x0 | TX3_CH3_MAP<br>TX3 Channel 3 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 11:8  | R/W | 0x0 | TX3_CH2_MAP<br>TX3 Channel 2 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample                             |

|     |     |     |                                                                                                                                     |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | ...<br>1111: 16th Sample                                                                                                            |
| 7:4 | R/W | 0x0 | TX3_CH1_MAP<br>TX3 Channel 1 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |
| 3:0 | R/W | 0x0 | TX3_CH0_MAP<br>TX3 Channel 0 Mapping<br>0000: 1st Sample<br>...<br>0111: 8th Sample<br>1000: 9th Sample<br>...<br>1111: 16th Sample |

#### 9.1.6.26. 0x0064 I2S/PCM RX Channel Select Register(Default Value: 0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: I2S/PCM_RXCHSEL                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:22          | /          | /           | /                                                                                                                                                                                      |
| 21:20          | R/W        | 0x0         | RX_OFFSET<br>RX Offset Tune(RX Data offset to LRCK)<br>0: No offset<br>n: Data is offset by n BCLKs to LRCK                                                                            |
| 19:16          | R/W        | 0x0         | RX_CHSEL<br>RX Channel (Slot) Number Select for Input<br>0000: 1 channel or slot<br>...<br>0111: 8 channels or slots<br>1000: 9 channels or slots<br>...<br>1111: 16 channels or slots |
| 15:0           | /          | /           | /                                                                                                                                                                                      |

#### 9.1.6.27. 0x0068 I2S/PCM RX Channel Mapping Register0(Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: I2S/PCM_RXCHMAP0 |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |

|       |     |     |                                                                                                                                                    |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | /   | /   | /                                                                                                                                                  |
| 29:24 | R/W | 0x0 | <b>RX_CH15_MAP</b><br>RX Channel 15 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 23:22 | /   | /   | /                                                                                                                                                  |
| 21:16 | R/W | 0x0 | <b>RX_CH14_MAP</b><br>RX Channel 14 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 15:14 | /   | /   | /                                                                                                                                                  |
| 13:8  | R/W | 0x0 | <b>RX_CH13_MAP</b><br>RX Channel 13 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 7:6   | /   | /   | /                                                                                                                                                  |
| 5:0   | R/W | 0x0 | <b>RX_CH12_MAP</b><br>RX Channel 12 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |

#### 9.1.6.28. 0x006C I2S/PCM RX Channel Mapping Register1(Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: I2S/PCM_RXCHMAP1             |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:30          | /          | /           | /                                           |
| 29:24          | R/W        | 0x0         | <b>RX_CH11_MAP</b><br>RX Channel 11 Mapping |

|       |     |     |                                                                                                                                             |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample                                         |
| 23:22 | /   | /   | /                                                                                                                                           |
| 21:16 | R/W | 0x0 | RX_CH10_MAP<br>RX Channel 10 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 15:14 | /   | /   | /                                                                                                                                           |
| 13:8  | R/W | 0x0 | RX_CH9_MAP<br>RX Channel 9 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample   |
| 7:6   | /   | /   | /                                                                                                                                           |
| 5:0   | R/W | 0x0 | RX_CH8_MAP<br>RX Channel 8 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample   |

#### 9.1.6.29. 0x0070 I2S/PCM RX Channel Mapping Register2(Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: I2S/PCM_RXCHMAP2                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:30          | /          | /           | /                                                                                     |
| 29:24          | R/W        | 0x0         | RX_CH7_MAP<br>RX Channel 7 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample |

|       |     |     |                                                                                                                                           |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 001000: 9th Sample<br>...<br>111111: 64th Sample                                                                                          |
| 23:22 | /   | /   | /                                                                                                                                         |
| 21:16 | R/W | 0x0 | RX_CH6_MAP<br>RX Channel 6 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 15:14 | /   | /   | /                                                                                                                                         |
| 13:8  | R/W | 0x0 | RX_CH5_MAP<br>RX Channel 5 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |
| 7:6   | /   | /   | /                                                                                                                                         |
| 5:0   | R/W | 0x0 | RX_CH4_MAP<br>RX Channel 4 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |

#### 9.1.6.30. 0x0074 I2S/PCM RX Channel Mapping Register3(Default Value: 0x0000\_0000)

| Offset: 0x0074 |            |             | Register Name: I2S/PCM_RXCHMAP3                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:30          | /          | /           | /                                                                                                                                         |
| 29:24          | R/W        | 0x0         | RX_CH3_MAP<br>RX Channel 3 Mapping<br>000000: 1st Sample<br>...<br>000111: 8th Sample<br>001000: 9th Sample<br>...<br>111111: 64th Sample |

|       |     |     |                                                                                                                                                         |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:22 | /   | /   | /                                                                                                                                                       |
| 21:16 | R/W | 0x0 | <p>RX_CH2_MAP<br/>RX Channel 2 Mapping<br/>000000: 1st Sample<br/>...<br/>000111: 8th Sample<br/>001000: 9th Sample<br/>...<br/>111111: 64th Sample</p> |
| 15:14 | /   | /   | /                                                                                                                                                       |
| 13:8  | R/W | 0x0 | <p>RX_CH1_MAP<br/>RX Channel 1 Mapping<br/>000000: 1st Sample<br/>...<br/>000111: 8th Sample<br/>001000: 9th Sample<br/>...<br/>111111: 64th Sample</p> |
| 7:6   | /   | /   | /                                                                                                                                                       |
| 5:0   | R/W | 0x0 | <p>RX_CH0_MAP<br/>RX Channel 0 Mapping<br/>000000: 1st Sample<br/>...<br/>000111: 8th Sample<br/>001000: 9th Sample<br/>...<br/>111111: 64th Sample</p> |

## 9.2. DMIC

### 9.2.1. Overview

The DMIC controller supports one 8-channels digital microphone interface, the DMIC controller can output 128fs or 64fs (fs= ADC sample rate).

The DMIC controller includes the following features:

- Supports up to 8 channels
- Sample rate from 8 kHz to 48 kHz

### 9.2.2. Block Diagram

Figure 9-9 shows a block diagram of the DMIC.



Figure 9- 9. DMIC Block Diagram

### 9.2.3. Operations and Functional Descriptions

#### 9.2.3.1. External Signals

Table 9-4 describes the external signals of DMIC.

Table 9- 4. DMIC External Signals

| Signal     | Description                     | Type |
|------------|---------------------------------|------|
| DMIC_CLK   | Digital Microphone Clock Output | O    |
| DMIC_DATA0 | Digital Microphone Data Input   | I    |
| DMIC_DATA1 | Digital Microphone Data Input   | I    |
| DMIC_DATA2 | Digital Microphone Data Input   | I    |
| DMIC_DATA3 | Digital Microphone Data Input   | I    |

### 9.2.3.2. Clock Sources

Table 9-5 describes the clock source for DMIC. Users can see **Clock Controller Unit(CCU)** for clock setting, configuration and gating information.

Table 9- 5. DMIC Clock Sources

| Clock Sources | Description                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_AUDIO(4X) | The 98.304 MHz frequency generated by PLL_AUDIO(4X) to produce 48 kHz sample frequency.                                                                |
| PLL_COM_AUDIO | The 90.3168 MHz frequency generated by PLL_COM_AUDIO is divided by 4(=22.5792 MHz) and then passed to the module to produce 44.1 kHz sample frequency. |
| APB CLK       | The frequency must be greater than 24MHz in order to write RXFIFO data.                                                                                |

### 9.2.3.3. Operation Mode

The software operation of the DMIC is divided into five steps: system setup, DMIC initialization, channel setup, DMA setup and Enable/Disable module. Five steps are described in detail in the following sections.



Figure 9- 10. DMIC Operation Mode

### 9.2.3.3.1. System Setup and DMIC Initialization

The first step in the system setup is properly programming the GPIO. Because the DMIC port is a multiplex pin. You can find the function in the pin multiplex specification.

The clock source for the DMIC should be followed. At first you must disable the PLL\_AUDIO through the PLL\_ENABLE bit of **PLL\_AUDIO\_CTRL\_REG** in the CCU. The second step, you must set up the frequency of the PLL\_AUDIO in the **PLL\_AUDIO\_CTRL\_REG**. Then enable PLL\_AUDIO. After that, you must open the DMIC gating through the **DMIC\_CLK\_REG** when you checkout that the LOCK bit of **PLL\_AUDIO\_CTRL\_REG** becomes 1. At last, you must reset and open the DMIC bus gating in the **DMIC\_BGR\_REG**.

After the system setup, the register of DMIC can be setup. At first, you should initialize the DMIC. You should close the **globe enable bit(DMIC\_EN[8])**, **data channel enable bit(DMIC\_EN[7:0])** by writing 0 to it. After that, you must flush the RXFIFO by writing 1 to **DMIC\_RXFIFO\_CTR[31]**. At last, you can clear the Data/RXFIFO counter by writing 1 to **DMIC\_RXFIFO\_STA, DMIC\_CNT**.

### 9.2.3.3.2. Channel Setup and DMA Setup

You can set up the sample rate, the sample resolution, the over sample rate, the channel number, the RXFIFO output mode and the RXFIFO trigger level and so on. The setup of register can be found in the specification.

The DMIC supports two methods to transfer the data. The most common way is DMA, the setup of DMA can be found in the DMA specification. In this module, you just enable the DRQ.

### 9.2.3.3.3. Enable and Disable DMIC

To enable the function, you can enable **data channel enable bit** (DMIC\_EN[7:0]) by writing 1 to it. After that, you must enable DMIC by writing 1 to the **Globe Enable bit** (DMIC\_EN[8]). Write 0 to **Globe Enable bit** to disable DMIC.

## 9.2.4. Register List

| Module Name | Base Address |
|-------------|--------------|
| DMIC        | 0x05095000   |

| Register Name | Offset | Description                    |
|---------------|--------|--------------------------------|
| DMIC_EN       | 0x0000 | DMIC Enable Control Register   |
| DMIC_SR       | 0x0004 | DMIC Sample Rate Register      |
| DMIC_CTR      | 0x0008 | DMIC Control Register          |
| DMIC_DATA     | 0x0010 | DMIC Data Register             |
| DMIC_INTC     | 0x0014 | MIC Interrupt Control Register |

|                     |        |                                          |
|---------------------|--------|------------------------------------------|
| DMIC_INTS           | 0x0018 | DMIC Interrupt Status Register           |
| DMIC_RXFIFO_CTR     | 0x001C | DMIC RXFIFO Control Register             |
| DMIC_RXFIFO_STA     | 0x0020 | DMIC RXFIFO Status Register              |
| DMIC_CH_NUM         | 0x0024 | DMIC Channel Numbers Register            |
| DMIC_CH_MAP         | 0x0028 | DMIC Channel Mapping Register            |
| DMIC_CNT            | 0x002C | DMIC Counter Register                    |
| DATA0_DATA1_VOL_CTR | 0x0030 | Data0 and Data1 Volume Control Register  |
| DATA2_DATA3_VOL_CTR | 0x0034 | Data2 And Data3 Volume Control Register  |
| HPF_EN_CTR          | 0x0038 | High Pass Filter Enable Control Register |
| HPF_COEF_REG        | 0x003C | High Pass Filter Coef Register           |
| HPF_GAIN_REG        | 0x0040 | High Pass Filter Gain Register           |

### 9.2.5. Register Description

#### 9.2.5.1. 0x0000 DMIC Enable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: DMIC_EN                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:30          | /          | /           | /                                                                                               |
| 29             | R/W        | 0x0         | <b>RX_SYNC_EN</b><br>Audio/I2S/DMIC RX (GLOBE_EN) Synchronize Enable<br>0: Disable<br>1: Enable |
| 28             | R/W        | 0x0         | <b>RX_EN_MUX</b><br>Audio RX (GLOBE_EN) Enable MUX<br>0: Disable<br>1: Enable                   |
| 27:9           | /          | /           | /                                                                                               |
| 8              | R/W        | 0x0         | <b>GLOBE_EN</b><br>DMIC Globe Enable<br>0: Disable<br>1: Enable                                 |
| 7              | R/W        | 0x0         | <b>DATA3_CHR_EN</b><br>DATA3 Right Channel Enable<br>0: Disable<br>1: Enable                    |
| 6              | R/W        | 0x0         | <b>DATA3_CHL_EN</b><br>DATA3 Left Channel Enable<br>0: Disable<br>1: Enable                     |
| 5              | R/W        | 0x0         | <b>DATA2_CHR_EN</b><br>DATA2 Right Channel Enable<br>0: Disable                                 |

|   |     |     |                                                                       |
|---|-----|-----|-----------------------------------------------------------------------|
|   |     |     | 1: Enable                                                             |
| 4 | R/W | 0x0 | DATA2_CHL_EN<br>DATA2 Left Channel Enable<br>0: Disable<br>1: Enable  |
| 3 | R/W | 0x0 | DATA1_CHR_EN<br>DATA1 Right Channel Enable<br>0: Disable<br>1: Enable |
| 2 | R/W | 0x0 | DATA1_CHL_EN<br>DATA1 Left Channel Enable<br>0: Disable<br>1: Enable  |
| 1 | R/W | 0x0 | DATA0_CHR_EN<br>DATA0 Right Channel Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | DATA0_CHL_EN<br>DATA0 Left Channel Enable<br>0: Disable<br>1: Enable  |

#### 9.2.5.2. 0x0004 DMIC Sample Rate Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: DMIC_SR                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                       |
| 2:0            | R/W        | 0x0         | DMIC_SR<br>Sample Rate of DMIC<br>000: 48 kHz<br>010: 24 kHz<br>100: 12 kHz<br>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. |

#### 9.2.5.3. 0x0008 DMIC Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: DMIC_CTR |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |

|       |     |     |                                                                                                                  |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------|
| 31:11 | /   | /   | /                                                                                                                |
| 10:9  | R/W | 0x0 | DMICFDT<br>DMIC RXFIFO Delay Time for Writing Data after GLOBE_EN<br>00: 5ms<br>01: 10ms<br>10: 20ms<br>11: 30ms |
| 8     | R/W | 0x0 | DMICDFEN<br>DMIC RXFIFO Delay Function for Writing Data after GLOBE_EN<br>0: Disable<br>1: Enable                |
| 7     | R/W | 0x0 | DATA3 Left Data and Right Data Swap Enable<br>0: Disable<br>1: Enable                                            |
| 6     | R/W | 0x0 | DATA2 Left Data and Right Data Swap Enable<br>0: Disable<br>1: Enable                                            |
| 5     | R/W | 0x0 | DATA1 Left Data and Right Data Swap Enable<br>0: Disable<br>1: Enable                                            |
| 4     | R/W | 0x0 | DATA0 Left Data and Right Data Swap Enable<br>0: Disable<br>1: Enable                                            |
| 3:1   | /   | /   | /                                                                                                                |
| 0     | R/W | 0x0 | DMIC Oversample Rate<br>0: 128 (Support 8 kHz ~ 24 kHz)<br>1: 64 (Support 16 kHz ~ 48 kHz)                       |

#### 9.2.5.4. 0x0010 DMIC DATA Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DMIC_DATA |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | R          | 0x0         | DMIC_DATA                |

#### 9.2.5.5. 0x0014 DMIC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: DMIC_INTC                                             |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:3           | /          | /           | /                                                                    |
| 2              | R/W        | 0x0         | RXFIFO_DRQ_EN<br>DMIC RXFIFO Data Available DRQ Enable<br>0: Disable |

|   |     |     |                                                                                    |
|---|-----|-----|------------------------------------------------------------------------------------|
|   |     |     | 1: Enable                                                                          |
| 1 | R/W | 0x0 | RXFIFO_OVERRUN_IRQ_EN<br>DMIC RXFIFO Overrun IRQ Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | DATA_IRQ_EN<br>DMIC RXFIFO Data Available IRQ Enable<br>0: Disable<br>1: Enable    |

#### 9.2.5.6. 0x0018 DMIC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: DMIC_INTS                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:2           | /          | /           | /                                                                                                                                                                                                                         |
| 1              | R/W1C      | 0x0         | RXFIFO_OVERRUN_IRQ_PENDING<br>DMIC RXFIFO Overrun Pending Interrupt<br>0: No pending IRQ<br>1: RXFIFO overrun pending IRQ<br>Writing '1' to clear this interrupt or automatically clear if interrupt condition fails.     |
| 0              | R/W1C      | 0x0         | RXFIFO_DATA_IRQ_PENDING<br>DMIC RXFIFO Data Available Pending Interrupt<br>0: No pending IRQ<br>1: Data available pending IRQ<br>Writing '1' to clear this interrupt or automatically clear if interrupt condition fails. |

#### 9.2.5.7. 0x001C DMIC RXFIFO Control Register (Default Value: 0x0000\_0040)

| Offset: 0x001C |            |             | Register Name: DMIC_FIFO_CTR                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                               |
| 31             | R/W1C      | 0x0         | DMIC_RXFIFO_FLUSH<br>DMIC RXFIFO Flush<br>Writing '1' to flush RXFIFO, self clear to '0'                                                                                                                                                                  |
| 30:10          | /          | /           | /                                                                                                                                                                                                                                                         |
| 9              | R/W        | 0x0         | RXFIFO_MODE<br>RXFIFO Output Mode (Mode 0, 1)<br>0: Expanding '0' at LSB of RXFIFO register<br>1: Expanding received sample sign bit at MSB of RXFIFO register<br><br>For 24-bit received audio sample:<br>Mode 0: APB_RDATA[31:0] = {RXFIFO[20:0],11'h0} |

|     |     |      |                                                                                                                                                                                                                                                    |
|-----|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |      | Mode 1: APB_RDATA[31:0] = {8{RXFIFO[20]}, RXFIFO[20:0], 3'h0}<br><br>For 16-bit received audio sample:<br>Mode 0: APB_RDATA[31:0] = {RXFIFO[20:5], 16'h0}<br>Mode 1: APB_RDATA[31:0] = {16{RXFIFO[20]}, RXFIFO[20:5]}                              |
| 8   | R/W | 0x0  | Sample_Resolution<br>0: 16-bit<br>1: 24-bit                                                                                                                                                                                                        |
| 7:0 | R/W | 0x40 | RXFIFO_TRG_LEVEL<br>RXFIFO Trigger Level (TRLV[7:0])<br>Interrupt and DMA request trigger level for DMIC RXFIFO normal condition<br>IRQ/DRQ Generated when WLEVEL > TRLV[7:0])<br>WLEVEL represents the number of valid samples in the DMIC RXFIFO |

#### 9.2.5.8. 0x0020 DMIC RXFIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: DMIC_RXFIFO_STA                             |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:8           | /          | /           | /                                                          |
| 7:0            | R/W        | 0x0         | DMIC_DATA_CNT<br>DMIC RXFIFO Available Sample Word Counter |

#### 9.2.5.9. 0x0024 DMIC Channel Numbers Register (Default Value: 0x0000\_0001)

| Offset: 0x0024 |            |             | Register Name: DMIC_CH_NUM                            |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:3           | /          | /           | /                                                     |
| 2:0            | R/W        | 0x1         | DMIC_CH_NUM<br>DMIC enable channel numbers are (N+1). |

#### 9.2.5.10. 0x0028 DMIC Channel Mapping Register (Default Value: 0x7654\_3210)

| Offset: 0x0028 |            |             | Register Name: DMIC_CH_MAP                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:28          | R/W        | 0x7         | DMIC_CH7_MAP<br>DMIC Channel 7 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel |

|       |     |     |                                                                                                                                                                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel                                                                                                                                                                                         |
| 27:24 | R/W | 0x6 | DMIC_CH6_MAP<br>DMIC Channel 6 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 23:20 | R/W | 0x5 | DMIC_CH5_MAP<br>DMIC Channel 5 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 19:16 | R/W | 0x4 | DMIC_CH4_MAP<br>DMIC Channel 4 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 15:12 | R/W | 0x3 | DMIC_CH3_MAP<br>DMIC Channel 3 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 11:8  | R/W | 0x2 | DMIC_CH2_MAP<br>DMIC Channel 2 Mapping                                                                                                                                                                                                                                     |

|     |     |     |                                                                                                                                                                                                                                                                            |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel                                           |
| 7:4 | R/W | 0x1 | DMIC_CH1_MAP<br>DMIC Channel 1 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 3:0 | R/W | 0x0 | DMIC_CH0_MAP<br>DMIC Channel0 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel  |

#### 9.2.5.11. 0x002C DMIC Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: DMIC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:0           | R/W        | 0x0         | DMIC_CNT<br>RX Sample Counter<br>The audio sample number of writing into RXFIFO. 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.<br><b>Note: It is used for Audio/Video Synchronization.</b> |

**9.2.5.12. 0x0030 DATA0 and DATA1 Volume Control Register (Default Value: 0xA0A0\_A0A0)**

| Offset: 0x0030 |            |             | Register Name: DATA0_DATA1_VOL_CTR                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:24          | R/W        | 0xA0        | <p>DATA1L_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 23:16          | R/W        | 0xA0        | <p>DATA1R_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 15:8           | R/W        | 0xA0        | <p>DATA0L_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 7:0            | R/W        | 0xA0        | <p>DATA0R_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |

**9.2.5.13. 0x0034 DATA2 and DATA3 Volume Control Register (Default Value: 0xA0A0\_A0A0)**

| Offset: 0x0034 |            |             | Register Name: DATA2_DATA3_VOL_CTR                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:24          | R/W        | 0xA0        | <p>DATA3L_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 23:16          | R/W        | 0xA0        | <p>DATA3R_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 15:8           | R/W        | 0xA0        | <p>DATA2L_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |
| 7:0            | R/W        | 0xA0        | <p>DATA2R_VOL<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>.....<br/>0x9F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>.....<br/>0xFF: 71.25 dB</p> |

#### 9.2.5.14. 0x0038 High Pass Filter Enable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: HPF_EN_CTR                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:8           | /          | /           | /                                                                                                 |
| 7              | R/W        | 0x0         | <b>HPF_DATA3_CHR_EN</b><br>High Pass Filter DATA3 Right Channel Enable<br>0: Disable<br>1: Enable |
| 6              | R/W        | 0x0         | <b>HPF_DATA3_CHL_EN</b><br>High Pass Filter DATA3 Left Channel Enable<br>0: Disable<br>1: Enable  |
| 5              | R/W        | 0x0         | <b>HPF_DATA2_CHR_EN</b><br>High Pass Filter DATA2 Right Channel Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | <b>HPF_DATA2_CHL_EN</b><br>High Pass Filter DATA2 Left Channel Enable<br>0: Disable<br>1: Enable  |
| 3              | R/W        | 0x0         | <b>HPF_DATA1_CHR_EN</b><br>High Pass Filter DATA1 Right Channel Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | <b>HPF_DATA1_CHL_EN</b><br>High Pass Filter DATA1 Left Channel Enable<br>0: Disable<br>1: Enable  |
| 1              | R/W        | 0x0         | <b>HPF_DATA0_CHR_EN</b><br>High Pass Filter DATA0 Right Channel Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | <b>HPF_DATA0_CHL_EN</b><br>High Pass Filter DATA0 Left Channel Enable<br>0: Disable<br>1: Enable  |

#### 9.2.5.15. 0x003C High Pass Filter Coef Register (Default Value: 0x00FF\_AA45)

| Offset: 0x003C |            |             | Register Name: HPF_COEF_REG  |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:0           | R/W        | 0x00FFAA45  | High Pass Filter Coefficient |

#### 9.2.5.16. 0x0040 High Pass Filter Gain Register (Default Value: 0x00FF\_D522)

| Offset: 0x0040 |            | Register Name: HPF_GAIN_REG |                       |
|----------------|------------|-----------------------------|-----------------------|
| Bit            | Read/Write | Default/Hex                 | Description           |
| 31:0           | R/W        | 0x00FFD522                  | High Pass Filter Gain |

Confidential

## 9.3. OWA

### 9.3.1. Overview

The One Wire Audio(OWA) provides a serial bus interface for audio data between system. This interface is widely used for consumer audio.

The OWA controller includes the following features:

- IEC-60958 transmitter functionality
- Compliance with S/PDIF interface
- Supports channel status insertion for the transmitter
- Hardware parity generation on the transmitter
- One 128×24bits TXFIFO for audio data transfer
- Programmable FIFO thresholds
- Interrupt and DMA support
- Supports 16-bit, 20-bit, 24-bit data formats

### 9.3.2. Block Diagram

The block diagram of the OWA is shown as follows.



Figure 9- 11. OWA Block Diagram

### 9.3.3. Operations and Functional Descriptions

#### 9.3.3.1. External Signals

OWA is a Biphase-Mark Encoding Digital Audio Transfer protocol. In this protocol, the clock signal and data signal are transferred in the same line. Table 9-6 describes the external signals of OWA. OWA\_OUT is output pin for output clock and data.

Table 9- 6. OWA External Signals

| Signal Name | Description | Type |
|-------------|-------------|------|
| OWA_OUT     | OWA output  | O    |

#### 9.3.3.2. Clock Sources

Table 9-7 describes the clock sources for OWA. Users can see **Chapter 3.3.CCU** for clock setting, configuration and gating information.

Table 9- 7. OWA Clock Sources

| Clock Name    | Description                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_AUDIO(4X) | The 98.304 MHz frequency generated by PLL_AUDIO(4X) to produce 48 kHz sample frequency.                                                                |
| PLL_COM_AUDIO | The 90.3168 MHz frequency generated by PLL_COM_AUDIO is divided by 4(=22.5792 MHz) and then passed to the module to produce 44.1 kHz sample frequency. |

#### 9.3.3.3. Biphase-Mark Code (BMC)

In OWA format, the digital signal is coded using the biphase-mark code (BMC). The clock, frame, and data are embedded in only one signal—the data pin. In the BMC system, each data bit is encoded into two logical states (00, 01, 10, or 11) at the pin. Figure 9-12 and Table 9-8 show how data is encoded to the BMC format.

As shown in Figure 9-12, the frequency of the clock is twice the data bit rate. In addition, the clock is always programmed to 128xfs, where fs is the sample rate. The device receiving in OWA format can recover the clock and frame information from the BMC signal.



Figure 9- 12. OWA Biphase-Mark Code

Table 9- 8. Biphase-Mark Encoder

| Data | Previous State | BMC |
|------|----------------|-----|
| 0    | 0              | 11  |
| 0    | 1              | 00  |
| 1    | 0              | 10  |
| 1    | 1              | 01  |

### 9.3.3.4. OWA Transmit Format

The OWA supports digital audio data transfer out and receive in. And it supports full-duplex synchronous work mode. Software can set the work mode by the OWA Control Register.

Every audio sample transmitted in a subframe consists of 32-bit, numbered from 0 to 31. Figure 9-13 shows a subframe.



Figure 9- 13. OWA Sub-Frame Format

**Bit 0-3** carry one of the four permitted preambles to signify the type of audio sample in the current subframe. The preamble is not encoded in BMC format, and therefore the preamble code can contain more than two consecutive 0

or 1 logical states in a row. See Table 9-8.

**Bit 4-27** carry the audio sample word in linear 2s-complement representation. The most-significant bit (MSB) is carried by bit 27. When a 24-bit coding range is used, the least-significant bit (LSB) is in bit 4. When a 20-bit coding range is used, bit 8-27 carry the audio sample word with the LSB in bit 8. Bit 4-7 may be used for other applications and are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 20 or 24), the unused LSBs are set to logical 0. For a nonlinear PCM audio application or a data application, the main data field may carry any other information.

**Bit 28** carries the validity bit (V) associated with the main data field in the subframe.

**Bit 29** carries the user data channel (U) associated with the main data field in the subframe.

**Bit 30** carries the channel status information (C) associated with the main data field in the subframe. The channel status indicates if the data in the subframe is digital audio or some other type of data.

**Bit 31** carries a parity bit (P) such that bit 4-31 carry an even number of 1s and an even number of 0s (even parity). As shown in Table 9-9, the preambles (bit 0-3) are also defined with even parity.

Table 9- 9. Preamble Codes

| Preamble Code | Previous Logical State | Logical State | Description                     |
|---------------|------------------------|---------------|---------------------------------|
| B(or Z)       | 0                      | 1110 1000     | Start of a block and subframe 1 |
| M(or X)       | 0                      | 1110 0010     | Subframe 1                      |
| W(or Y)       | 0                      | 1110 0100     | Subframe 2                      |



Figure 9- 14. OWA Frame/Block Format

### 9.3.3.5. Operation Modes

The software operation of the OWA is divided into five steps: system setup, OWA initialization, channel setup, DMA setup and enable/disable module. These five steps are described in detail in the following sections.



Figure 9- 15. OWA Operation Flow

### (1) System Setup and OWA Initialization

The first step in the OWA initialization is properly programming the GPIO. Because the OWA port is a multiplex pin. You can find the function in the **Port Controller**.

The clock source for the OWA should be followed. At first you must reset the audio PLL in the **CCU**. The second step, you must setup the frequency of the Audio PLL. After that, you must open the OWA gating. At last, you must open the OWA bus gating.

After the system setup, the register of OWA can be setup. At first, you should reset the OWA by writing 1 to **OWA\_CTL[0]** and clear the TX FIFO by writing 1 to **OWA\_FCTL[30]**. After that you should enable the globe enable bit by writing 1 to **OWA\_CTL[1]**, and clear the interrupt and TX counter by the **OWAISTA** and **OWATX\_CNT**.

### (2) Channel Setup and DMA Setup

The OWA supports two methods to transfer the data. The most common way is DMA, the configuration of DMA can be found in the **DMA**. In this module, you just enable the DRQ by writing the **OWA\_INT[7]**.

### (3) Enable and Disable OWA

To enable the function, you can enable TX by writing the **OWA\_TX\_CFIG[0]**. After that, you must enable OWA by writing 1 to the **GEN** bit in the **OWA\_CTL** register. Writing 0 to the **GEN** bit to disable process.

### 9.3.4. Register List

| Module Name | Base Address |
|-------------|--------------|
| OWA         | 0x05094000   |

| Register Name | Offset | Description                     |
|---------------|--------|---------------------------------|
| OWA_GEN_CTL   | 0x0000 | OWA General Control Register    |
| OWA_TX_CFIG   | 0x0004 | OWA TX Configuration Register   |
| OWAISTA       | 0x000C | OWA Interrupt Status Register   |
| OWAFCTL       | 0x0014 | OWA FIFO Control Register       |
| OWAFSTA       | 0x0018 | OWA FIFO Status Register        |
| OWAINT        | 0x001C | OWA Interrupt Control Register  |
| OWATX_FIFO    | 0x0020 | OWA TX FIFO Register            |
| OWATX_CNT     | 0x0024 | OWA TX Counter Register         |
| OWATX_CHSTA0  | 0x002C | OWA TX Channel Status Register0 |
| OWATX_CHSTA1  | 0x0030 | OWA TX Channel Status Register1 |

### 9.3.5. Register Description

#### 9.3.5.1. 0x0000 OWA General Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0000 |            |             | Register Name: OWA_CTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9:5            | R/W        | 0x4         | <p>MCLKDIV<br/>                     MCLK Clock Divide Ratio<br/>                     MCLK Divide Ratio from PLL_AUDIO<br/>                     00000: Divide by 128<br/>                     00001: Divide by 2<br/>                     00010: Divide by 4<br/>                     00011: Divide by 6<br/>                     00100: Divide by 8<br/>                     00101: Divide by 10<br/>                     00110: Divide by 12<br/>                     00111: Divide by 14<br/>                     01000: Divide by 16<br/>                     01001: Divide by 18<br/>                     01010: Divide by 20<br/>                     01011: Divide by 22<br/>                     01100: Divide by 24<br/>                     .....<br/>                     11111: Divide by 62</p> |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|   |     |     |                                                                                                                                              |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | R/W | 0x0 | MCLKEN<br>MCLK Enable<br>0: Disable<br>1: Enable                                                                                             |
| 2 | R/W | 0x0 | LOOP<br>Loop Back Test<br>0: Normal Mode<br>1: Loop Back Test<br>When setting to '1', DOUT and DIN need be connected.                        |
| 1 | R/W | 0x0 | GEN<br>Global Enable<br>A disable on this bit overrides any other block or channel enables and flushes all FIFOs.<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | RST<br>Reset<br>0: Normal<br>1: Reset<br>Self clear to 0.                                                                                    |

### 9.3.5.2. 0x0004 OWA TX Configure Register (Default Value: 0x0000\_00F0)

| Offset: 0x0004 |            |             | Register Name: OWA_TX_CFIG                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31             | R/W        | 0x0         | TX_SINGLE_MODE<br>Tx Single Channel Mode<br>0: Disable<br>1: Enable                                                                                    |
| 30:18          | /          | /           | /                                                                                                                                                      |
| 17             | R/W        | 0x0         | ASS<br>Audio Sample Select with TX FIFO Underrun when<br>0: Sending 0<br>1: Sending the last audio<br><b>Note: This bit is only valid in PCM mode.</b> |
| 16             | R/W        | 0x0         | TX_AUDIO<br>TX Data Type<br>0: Linear PCM (Valid bit of both sub-frame set to 0 )<br>1: Non-audio(Valid bit of both sub-frame set to 1)                |
| 15:9           | /          | /           | /                                                                                                                                                      |
| 8:4            | R/W        | 0xF         | TX_RATIO<br>TX Clock Divide Ratio<br>Clock divide ratio = TX_TATIO +1<br>Fs= PLL_AUDIO/[(TX_TATIO +1)*64*2]                                            |

|     |     |     |                                                                                                       |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------|
| 3:2 | R/W | 0x0 | TX_SF<br>TX Sample Format<br>00: 16 bits<br>01: 20 bits<br>10: 24 bits<br>11: Reserved                |
| 1   | R/W | 0x0 | TX_CHM<br>CHSTMODE<br>0: Channel status A&B set to 0<br>1: Channel status A&B generated from TX_CHSTA |
| 0   | R/W | 0x0 | TXEN<br>0: Disabled<br>1: Enabled                                                                     |

### 9.3.5.3. 0x000C OWA Interrupt Status Register (Default Value: 0x0000\_0010)

| Offset: 0x000C |            |             | Register Name: OWAISTA                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:7           | /          | /           | /                                                                                                                                                                                                  |
| 6              | R/W1C      | 0x0         | TXU_INT<br>TX FIFO Underrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Underrun Pending Interrupt<br>Writing "1" to clear this interrupt.                                                   |
| 5              | R/W1C      | 0x0         | TXO_INT<br>TX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Overrun Pending Interrupt<br>Writing "1" to clear this interrupt.                                                     |
| 4              | R/W1C      | 0x1         | TXE_INT<br>TX FIFO Empty Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Empty Pending Interrupt<br>Writing "1" to clear this interrupt or automatically clear if the interrupt condition fails. |
| 3:0            | /          | /           | /                                                                                                                                                                                                  |

### 9.3.5.4. 0x0014 OWA FIFO Control Register (Default Value: 0x0004\_0200)

| Offset: 0x0014 |            |             | Register Name: OWA_FCTL    |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31             | R/W        | 0x0         | HUB_EN<br>Audio Hub Enable |

|       |       |      |                                                                                                                                                                                                                                                                                        |
|-------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       |      | 0: Disable<br>1: Enable                                                                                                                                                                                                                                                                |
| 30    | R/W1C | 0x0  | FTX<br>Write '1' to flush TXFIFO, self clear to '0'.                                                                                                                                                                                                                                   |
| 29:20 | /     | /    | /                                                                                                                                                                                                                                                                                      |
| 19:12 | R/W   | 0x40 | TXTL<br>TX FIFO Empty Trigger Level<br>Interrupt and DMA request trigger level for TX FIFO normal condition.<br>Trigger Level = TXTL                                                                                                                                                   |
| 11:3  | /     | /    | /                                                                                                                                                                                                                                                                                      |
| 2     | R/W   | 0x0  | TXIM<br>TXFIFO Input Mode(Mode0, 1)<br>0: Valid data at the MSB of TXFIFO Register<br>1: Valid data at the LSB of TXFIFO Register<br>Example for 20-bit transmitted audio sample:<br>Mode 0: TXFIFO[23:0] = {APB_WDATA[31:12], 4'h0}<br>Mode 1: TXFIFO[23:0] = {APB_WDATA[19:0], 4'h0} |
| 1:0   | /     | /    | /                                                                                                                                                                                                                                                                                      |

#### 9.3.5.5. 0x0018 OWA FIFO Status Register (Default Value: 0x8080\_0000)

| Offset: 0x0018 |            |             | Register Name: OWA_FSTA                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31             | R          | 0x1         | TXE<br>TXFIFO Empty (indicate TXFIFO is not full)<br>0: No room for new sample in TXFIFO<br>1: More than one room for new sample in TXFIFO ( >=1 Word ) |
| 30:24          | /          | /           | /                                                                                                                                                       |
| 23:0           | R          | 0x80        | TXE_CNT<br>TXFIFO Empty Space Word Counter                                                                                                              |

#### 9.3.5.6. 0x001C OWA Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: OWA_INT                                       |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:8           | /          | /           | /                                                            |
| 7              | R/W        | 0x0         | TX_DRQ<br>TXFIFO Empty DRQ Enable<br>0: Disable<br>1: Enable |
| 6              | R/W        | 0x0         | TXUI_EN<br>TXFIFO Underrun Interrupt Enable                  |

|     |     |     |                                                                       |
|-----|-----|-----|-----------------------------------------------------------------------|
|     |     |     | 0: Disable<br>1: Enable                                               |
| 5   | R/W | 0x0 | TXOI_EN<br>TXFIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable |
| 4   | R/W | 0x0 | TXEI_EN<br>TXFIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable   |
| 3:0 | /   | /   | /                                                                     |

### 9.3.5.7. 0x0020 OWA TX FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: OWA_TXFIFO                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:0           | W          | 0x0         | TX_DATA<br>Transmitting A, B channel data should be written this register one by one.<br>The A channel data is first and then the B channel data. |

### 9.3.5.8. 0x0024 OWA TX Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: OWA_TX_CNT                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31:0           | R/W        | 0x0         | TX_CNT<br>TX Sample Counter<br>This is the audio sample number sent into TXFIFO.<br>When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX sample counter register can be set to any initial value at any time. After updated by the initial value, the counter register should count on base of this initial value. |

### 9.3.5.9. 0x002C OWA TX Channel Status Register0 (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: OWA_TX_CHSTA0                       |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31: 30         | /          | /           | /                                                  |
| 29:28          | R/W        | 0x0         | CA<br>Clock Accuracy<br>00: Level 2<br>01: Level 1 |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 10: Level 3<br>11: Not matched                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27:24 | R/W | 0x0 | FREQ<br>Sample Frequency<br>0000: 44.1 kHz<br>0001: Not indicated<br>0010: 48 kHz<br>0011: 32 kHz<br>0100: 22.05 kHz<br>0101: Reserved<br>0110: 24 kHz<br>0111: Reserved<br>1000: Reserved<br>1001: 768 kHz<br>1010: 96 kHz<br>1011: Reserved<br>1100: 176.4 kHz<br>1101: Reserved<br>1110: 192 kHz<br>1111: Reserved                                                                                                                              |
| 23:20 | R/W | 0x0 | CN<br>Channel Number                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 19:16 | R/W | 0x0 | SN<br>Source Number                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:8  | R/W | 0x0 | CC<br>Category Code<br>Indicates the kind of equipment that generates the digital audio interface signal.                                                                                                                                                                                                                                                                                                                                          |
| 7:6   | R/W | 0x0 | MODE<br>Mode<br>00: Default Mode<br>01~11: Reserved                                                                                                                                                                                                                                                                                                                                                                                                |
| 5:3   | R/W | 0x0 | EMP<br>Emphasis<br>Additional format information<br>For bit 1 = "0", Linear PCM audio mode:<br>000: 2 audio channels without pre-emphasis<br>001: 2 audio channels with 50 µs / 15 µs pre-emphasis<br>010: Reserved (for 2 audio channels with pre-emphasis)<br>011: Reserved (for 2 audio channels with pre-emphasis)<br>100~111: Reserved<br><br>For bit 1 = "1", other than Linear PCM applications:<br>000: Default state<br>001~111: Reserved |

|   |     |     |                                                                                                                     |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------|
| 2 | R/W | 0x0 | CP<br>Copyright<br>0: Copyright is asserted<br>1: No copyright is asserted                                          |
| 1 | R/W | 0x0 | TYPE<br>Audio Data Type<br>0: Linear PCM sample<br>1: Non-linear PCM audio                                          |
| 0 | R/W | 0x0 | PRO<br>Application Type<br>0: Consumer application<br>1: Professional application<br>This bit must be fixed to "0". |

### 9.3.5.10. 0x0030 OWA TX Channel Status Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: OWA_TX_CHSTA1                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                     |
| 31:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                               |
| 9:8            | R/W        | 0x0         | CGMS_A<br>00: Copying is permitted without restriction<br>01: One generation of copies may be made<br>10: Condition not be used<br>11: No copying is permitted                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | ORIG_FREQ<br>Original Sample Frequency<br>0000: Not indicated<br>0001: 192 kHz<br>0010: 12 kHz<br>0011: 176.4 kHz<br>0100: Reserved<br>0101: 96 kHz<br>0110: 8 kHz<br>0111: 88.2 kHz<br>1000: 16 kHz<br>1001: 24 kHz<br>1010: 11.025 kHz<br>1011: 22.05 kHz<br>1100: 32 kHz<br>1101: 48 kHz<br>1110: Reserved<br>1111: 44.1 kHz |
| 3:1            | R/W        | 0x0         | WL<br>Sample Word Length                                                                                                                                                                                                                                                                                                        |

|   |     |     |                                                                                                                                                                                                                                                                                                                                                       |
|---|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | <p>For bit 0 = "0":</p> <p>000: Not indicated</p> <p>001: 16 bits</p> <p>010: 18 bits</p> <p>100: 19 bits</p> <p>101: 20 bits</p> <p>110: 17 bits</p> <p>111: Reserved</p> <p>For bit 0 = "1":</p> <p>000: Not indicated</p> <p>001: 20 bits</p> <p>010: 22 bits</p> <p>100: 23 bits</p> <p>101: 24 bits</p> <p>110: 21 bits</p> <p>111: Reserved</p> |
| 0 | R/W | 0x0 | <p>MWL</p> <p>Max Word Length</p> <p>0: Maximum audio sample word length is 20 bits</p> <p>1: Maximum audio sample word length is 24 bits</p>                                                                                                                                                                                                         |

## 9.4. Audio Codec

### 9.4.1. Overview

The A133 is integrated with high-performance audio codec, including two high-quality playback DAC channels (95 dB SNR), two differential microphone inputs; two high-quality recording ADC channels (95 dB SNR), one stereo headphone output and one single-ended differential line output.

The Audio Codec has the following features:

- Two DAC channels
  - Supports 8 kHz to 192 kHz DAC sample rate
  - SNR 95 dB ± 3 dB
  - Supports 16-bit and 20-bit audio sample resolution
- Two audio outputs
  - One stereo headphone output (HPOUTL and HPOUTR)
  - One single-ended differential line output (LINEOUTLP and LINEOUTLN)
- Two ADC channels
  - Supports 8 kHz to 48 kHz ADC sample rate
  - SNR 95 dB ± 3 dB
  - Supports 16-bit and 20-bit audio sample resolution
- Two audio inputs
  - Two differential microphone inputs (MICIN1P/N and MICIN2P/N)
- Capless stereo headphone driver
  - 95 dB ± 3 dB SNR@A-weight, THD+N -77 dB ± 3 dB
  - Output Level 0.56 Vrms@10 kOhm, 0.4Vrms@16 Ohm
- Two low-noise analog microphone bias outputs
- Supports Dynamic Range Controller(DRC) adjusting the DAC playback and ADC capture
- One 128x20-bits FIFO for DAC data transmit, one 128x20-bits FIFO for ADC data receive
- Programmable FIFO thresholds
- Interrupt and DMA support

### 9.4.2. Block Diagram

Figure 9-16 shows the block diagram of Audio Codec.



Figure 9- 16. Audio Codec Block Diagram

#### 9.4.3. Operations and Functional Descriptions

##### 9.4.3.1. External Signals

###### 9.4.3.1.1. Analog I/O Pins

| Signal    | Type | Description                              |
|-----------|------|------------------------------------------|
| MICIN1P   | AI   | Positive differential input for MIC1     |
| MICIN1N   | AI   | Negative differential input for MIC1     |
| MICIN2P   | AI   | Positive differential input for MIC2     |
| MICIN2N   | AI   | Negative differential input for MIC2     |
| HPOUTL    | AO   | Headphone left output                    |
| HPOUTR    | AO   | Headphone right output                   |
| LINEOUTLP | AO   | Positive differential output for lineout |
| LINEOUTLN | AO   | Negative differential output for lineout |
| MIC_DET   | AI   | Headphone MIC detect                     |
| HP_DET    | AI   | Headphone Jack detect                    |

###### 9.4.3.1.2. Reference

| Signal  | Type | Description                                       |
|---------|------|---------------------------------------------------|
| MBIAS   | AO   | First bias voltage output for main microphone     |
| HBIAS   | AO   | Second bias voltage output for headset microphone |
| HPOUTFB | AI   | Pseudo differential headphone ground reference    |

|      |    |                            |
|------|----|----------------------------|
| VRA1 | AO | Internal reference voltage |
| VRA2 | AO | Internal reference voltage |

#### 9.4.3.1.3. Power/Ground

| Signal | Type | Description                            |
|--------|------|----------------------------------------|
| AVCC   | P    | Analog power 1.8 V                     |
| AGND   | G    | Analog ground                          |
| CPVIN  | P    | Analog power for LDO                   |
| CPVDD  | P    | Analog power for headphone charge pump |
| CPVEE  | P    | Charge pump negative voltage output    |
| VEE    | P    | PA negative voltage input              |

#### 9.4.3.2. Clock Sources

Figure 9-17 describes the Audio Codec clock source. Users can see **CCU** for clock setting, configuration and gating information.



Figure 9- 17. Audio Codec Clock Diagram

The clocks of digital part are from PLL\_AUDIO and PLL\_COM. The clock is connected to ADCCLK by configuring the reg0x0A54[24] of CCU module; and the clock is connected to DACCLK by configuring the reg0x0A50[24] of CCU module.

The clocks of analog part include CK\_ADC, CK\_DAC, CHHOSC, CK32K. Where, CK\_ADC and CK\_DAC are provided by the digital divider of codec. CHHOSC and CK32K are provided by system oscillator 24M. These clocks need ensure that VDD-SYS is not power-off.

#### 9.4.3.3. Reset System

##### 9.4.3.3.1. Digital Part Reset System

The SYS\_RST will be provided by the VDD\_SYS domain, which comes from VDD\_SYS domain and is produced by RTC domain. Each domain has the de-bounce to confirm whether the reset system is strong. The codec register part, MIX will be reset by the SYS\_RST during the power on or the system soft writing the reset control logic. The other parts will be reset by the soft configuration through writing register.



Figure 9- 18. Audio Codec Digital Part Reset System

##### 9.4.3.3.2. Analog Part Reset System

When AVCC is powered on, it will send the AVCC\_POR signal. And the AVCC\_POR signal passes the level shift and RC filter part to ADDA logic core, which will reset the AVCC analog part.



Figure 9- 19. Audio Codec Analog Part Reset System

#### 9.4.3.4. Data Path Diagram

Figure 9-20 shows a data path of the Audio Codec.



**Figure 9- 20. Audio Codec Data Path Diagram**

#### 9.4.3.5. Two ADC

The two ADC is used for recording sound and a reference signal. The sample rate of the two ADC is independent of DAC sample rate. The digital ADC part can be enabled/disabled by the bit[28] of the AC\_ADC\_FIFOC register.

#### 9.4.3.6. Stereo DAC

In order to save power, the DAC can be enabled/disabled by setting the bit[15:14] of the DAC\_REG register. The digital DAC part can be enabled/disabled by the bit[31] of the AC\_DAC\_DPC register.

#### 9.4.3.7. Analog Audio Input Port

The Codec supports four analog audio input paths:

- MICIN1P/N
- MICIN2P/N

MICIN1P/N, MICIN2P/N provide differential input. MICIN is high impedance, low capacitance input suitable for connection to a wide range of differential microphones of different dynamics and sensitive. The gain for each pre-amplifier can be set independently. MBIAS provide reference voltage for electret condenser type(ECM) microphones.

#### 9.4.3.8. Analog Audio Output Port

The Codec has two type analog output ports:

- LINEOUTLP
- LINEOUTLN
- HPOUTL
- HPOUTR

##### 9.4.3.8.1. LINEOUTL

LINEOUTL provides one differential output to drive line signals to external audio equipment. The LINEOUTLP/N output source is from DACL. The volume control is logarithmic with an 43.5 dB rang in 1.5 dB step from -43.5 dB to 0 dB. The LINEOUTL output buffer is powered up or down by the bit13 of the DAC\_REG register.

##### 9.4.3.8.2. Headphone Output

The headphone PA is powered up or down by the bit15(HPPA\_EN) of the HP\_REG register. 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 9- 21. Headphone Output Application

##### 9.4.3.8.3. External Accessory Detection

The codec provides external accessory detection functions which can sense the presence and impedance of external components. This can be used to detect the insertion and removal of headphone.

Headphone insertion is detected using the HP-DET pin, which must be connected to switch contacts within the jack socket. An interrupt event is generated whenever a headphone insertion or removal event is detected.

Microphones, push-buttons and other accessories can be detected via the MIC-DET pin. The presence of a microphone, and the status of a hook switch can be detected. This feature also can be used to detect push-button operation.

The 24 MHz oscillator clock is required for all of External accessory detection functions.



Figure 9- 22. External Accessory Detection

#### 9.4.3.9. Microphone BIAS

The MBIAS/HBIAS output provides a low noise reference voltage suitable for biasing electrets type microphones and the associated external resistor biasing network.

#### 9.4.3.10. Interrupt

Figure 9-23 describes the Audio Codec interrupt system.



Figure 9- 23. Audio Codec Interrupt System

#### 9.4.3.11. DAP

##### 9.4.3.11.1. DAP Data Flow



Figure 9- 24. DAP Data Flow

##### 9.4.3.11.2. HPF Function

The DAP has individual channel high pass filter (HPF, -3dB cutoff < 1Hz) that can be enable and disable. The filter cutoff frequency is less than 1 Hz that can be remove DC offset from ADC recording. The HPF can also be bypassed.



Figure 9- 25. HPF Function

##### 9.4.3.11.3. DRC Function

The DRC scheme has three thresholds, three offsets, and four slopes (all programmable). There is one ganged DRC for the left/right channels. The diagram of DRC input/output is as follows.



Figure 9- 26. DRC Block Diagram



**Figure 9- 27. DRC Static Curve Parameters**

Professional-quality dynamic range compression automatically adjusts volume to flatten volume level.

One DRC is for left/right, and one DRC is for subwoofer.

Each DRC has adjustable threshold, offset, and 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.

#### DRC parameter setting:

- **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 energy filter is to estimate the RMS value of the audio data stream into DRC, and has two parameters, which determines the time window over which RMS to be made. The parameter is computed by  $\alpha = 1 - e^{-2.2Ts/ta}$ .



**Figure 9- 28. Energy Filter Structure**

#### Compression Control

This element has ten 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 RMS of the signal 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}$$

There,  $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  $CT_{in} = -(-40dB)/6.0206 = 6.644$ ,  $CT_{in}$  is entered as a 32-bit number in 8.24 format.

Therefore,  $CT_{in} = 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}$

There, 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,  $Kc = 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 9-29. 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.2Ts/ta}$ .



**Figure 9- 29. Gain Smooth Filter**

## 9.4.4. Programming Guidelines

### 9.4.4.1. Playback Process

- (1) Codec initial: Open audio codec bus clock gating and de-assert bus reset through **AUDIO\_CODEC\_BGR\_REG**, configure PLL\_Audio frequency and enable PLL\_Audio through **PLL\_AUDIO\_CTRL\_REG**. Please refer to CCU in chapter 3.3 about detail.
- (2) Configure MIX path.
- (3) Set sample rate, configure data transfer format, enable DAC.
- (4) DMA configure and DMA request.
- (5) Enable DAC DRQ and DMA.

### 9.4.4.2. Recording Process

- (1) Codec initial: Open audio codec bus clock gating and de-assert bus reset through **AUDIO\_CODEC\_BGR\_REG**, configure PLL\_Audio frequency and enable PLL\_Audio through **PLL\_AUDIO\_CTRL\_REG**. Please refer to CCU in chapter 3.3 about detail.
- (2) Configure MIX path.
- (3) Set sample rate, configure data transfer format, enable ADC.
- (4) DMA configure and DMA request.
- (5) Enable ADC DRQ and DMA.

## 9.4.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| Audio Codec | 0x05096000   |

| 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_CTRL  | 0x0034 | ADC Volume Control 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                |

|                    |        |                                                                 |
|--------------------|--------|-----------------------------------------------------------------|
| 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_LPFLAT  | 0x0118 | DAC DRC Left Peak Filter Low Attack Time Coef 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_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_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_LLT     | 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        |
| 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_OPT      | 0x01B4 | DAC DRC Optimum 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_LPFBAT   | 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_LPFFRT   | 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_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_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                  |
| 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_LLT      | 0x0258 | ADC DRC Limiter Threshold Low Setting Register                  |
| AC_ADC_DRC_HKI      | 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_SFHT     | 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_SFHR     | 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_MNGLS    | 0x02A4 | ADC DRC MIN Gain High Setting Register                          |

|                        |        |                                                 |
|------------------------|--------|-------------------------------------------------|
| AC_ADC_DRC_MXGLS       | 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_OPT         | 0x02B4 | ADC DRC Optimum 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              |
| Analog Domain Register |        |                                                 |
| ADCL_REG               | 0x0300 | ADCL Analog Control Register                    |
| ADCR_REG               | 0x0304 | ADCR Analog Control Register                    |
| DAC_REG                | 0x0310 | DAC 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                            |

#### 9.4.6. Register Description

##### 9.4.6.1. 0x0000 DAC Digital Part Control Register(Default Value: 0x0000\_0000)

| 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]*(-1.16dB)<br>64 steps, -1.16dB/step                       |

|      |     |     |                                                       |
|------|-----|-----|-------------------------------------------------------|
| 11:1 | /   | /   | /                                                     |
| 0    | R/W | 0x0 | HUB_EN<br>Audio Hub Enable<br>0: Disable<br>1: Enable |

#### 9.4.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         | DAC_VOL_SEL<br>DAC Volume Control Selection Enable<br>0: Disable<br>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 |

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

|       |     |      |                                                                                                                                                                                                                                                                                                         |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 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 | 0x0  | FIR_VER<br>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 underrun<br>0: Sending zero<br>1: Sending last audio sample                                                                                                                                                                                              |
| 25:24 | R/W | 0x0  | FIFO_MODE<br>For 20-bit 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-bit 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, 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><b>Note: WLEVEL represents the number of valid samples in the TX FIFO.</b><br><b>Only TXTL[6:0] valid when TXMODE = 0</b> |
| 7     | /   | /    | /                                                                                                                                                                                                                                                                                                       |
| 6     | R/W | 0x0  | DAC_MONO_EN<br>DAC Mono Enable<br>0: Stereo, 64 levels FIFO                                                                                                                                                                                                                                             |

|   |      |     |                                                                                    |
|---|------|-----|------------------------------------------------------------------------------------|
|   |      |     | 1: mono, 128 levels FIFO<br>When enabled, L & R channel send same data.            |
| 5 | R/W  | 0x0 | TX_SAMPLE_BITS<br>Transmitting Audio Sample Resolution<br>0: 16 bits<br>1: 24 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 Underrun IRQ Enable<br>0: Disable<br>1: Enable    |
| 1 | R/W  | 0x0 | FIFO_OVERRUN_IRQ_EN<br>DAC FIFO Overrun 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'      |

#### 9.4.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 ( $\geq 1$ word)                                                        |
| 22:8           | R          | 0x80        | TXE_CNT<br>TX FIFO Empty Space Word Counter                                                                                                                                                  |
| 7:4            | /          | /           | /                                                                                                                                                                                            |
| 3              | R/W1C      | 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 automatically clear if interrupt condition fails. |

|   |       |     |                                                                                                                                                            |
|---|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | R/W1C | 0x0 | <b>TXU_INT</b><br>TX FIFO Underrun Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Underrun Pending Interrupt<br>Write '1' to clear this interrupt |
| 1 | R/W1C | 0x0 | <b>TXO_INT</b><br>TX FIFO Overrun Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Overrun Pending Interrupt<br>Write '1' to clear this interrupt   |
| 0 | /     | /   | /                                                                                                                                                          |

#### 9.4.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         | <b>TX_DATA</b><br>Transmitting left, right channel sample data should be written this register one by one. The left channel sample data is first and then the right channel sample. |

#### 9.4.6.6. 0x0024 DAC TX Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: AC_DAC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0           | R/W        | 0x0         | <b>TX_CNT</b><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 host IO, the TX sample counter register increases by one. The TX 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.<br><b>Note: It is used for Audio/Video Synchronization</b> |

#### 9.4.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         | <b>DAC_MODU_SELECT</b><br>DAC Modulator Debug<br>0: DAC Modulator Normal Mode |

|      |     |     |                                                                                                                                                           |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 1: DAC Modulator Debug Mode                                                                                                                               |
| 10:9 | R/W | 0x0 | <b>DAC_PATTERN_SELECT</b><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 | <b>CODEC_CLK_SELECT</b><br>CODEC Clock Source Select<br>0: CODEC Clock is from PLL<br>1: CODEC Clock is from OSC (for Debug)                              |
| 7    | /   | /   | /                                                                                                                                                         |
| 6    | R/W | 0x0 | <b>DA_SWP</b><br>DAC Output Channel Swap Enable<br>0: Disable<br>1: Enable                                                                                |
| 5:2  | /   | /   | /                                                                                                                                                         |
| 1:0  | R/W | 0x0 | <b>ADDA_LOOP_MODE</b><br>ADDA Loop Mode Select<br>00: Disable<br>01: ADDA LOOP MODE DACL/DACR connects to ADCL/ADCR<br>1X: Reserved                       |

#### 9.4.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                         | <b>ADFS</b><br>Sample Rate of ADC<br>000: 48 kHz<br>010: 24 kHz<br>100: 12 kHz<br>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 PLL_Audio Configure Bit |
| 28             | R/W        | 0x0                         | <b>EN_AD</b><br>ADC Digital Part Enable<br>0: Disable<br>1: Enable                                                                                                                                                                        |
| 27:26          | R/W        | 0x0                         | <b>ADCFDT</b><br>ADC FIFO Delay Time for writing data after EN_AD                                                                                                                                                                         |

|       |     |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|-----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 00:5ms<br>01:10ms<br>10:20ms<br>11:30ms                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 25    | R/W | 0x0  | ADCDFEN<br>ADC FIFO Delay Function for writing data after EN_AD<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                          |
| 24    | R/W | 0x0  | 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-bit 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><br>For 16-bit 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]} |
| 23:22 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 21    | R/W | 0x0  | RX_SYNC_EN<br>Audio/I2S/DMIC RX (EN_AD) Synchronize Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                               |
| 20    | R/W | 0x0  | RX_EN_MUX<br>Audio RX (EN_AD) Enable MUX<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                 |
| 19:18 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17    | R/W | 0x0  | ADC_VOL_SEL<br>ADC Volume Control Selection Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                       |
| 16    | R/W | 0x0  | RX_SAMPLE_BITS<br>Receiving Audio Sample Resolution<br>0: 16 bits<br>1: 20 bits                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:14 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:12 | R/W | 0x0  | ADC_CHANNEL_EN<br>Bit 13: ADCR enable<br>Bit 12: ADCL enable                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11    | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 10: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 normal condition                                                                                                                                                                                                                                                                                                                                     |

|   |      |     |                                                                                                                             |
|---|------|-----|-----------------------------------------------------------------------------------------------------------------------------|
|   |      |     | IRQ/DRQ Generated when WLEVEL > RXTL[5:0]<br><br><b>Note: WLEVEL represents the number of valid samples in the RX FIFO.</b> |
| 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'.                                          |

#### 9.4.6.9. 0x0034 ADC Volume Control Register(Default Value: 0x0000\_A0A0)

| Offset: 0x0034 |            |             | Register Name: ADC_VOL_CTRL                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                 |
| 15:8           | R/W        | 0xA0        | ADC_VOL_L<br>ADC 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        | ADC_VOL_R<br>ADC 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>0xFF = 71.25dB |
|--|--|--|-------------------------|

#### 9.4.6.10. 0x0038 ADC FIFO Status Register(Default Value : 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: AC_ADC_FIFOS                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:24          | /          | /           | /                                                                                                                                                                                               |
| 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 (>= 1 word)                                                                                   |
| 22:15          | /          | /           | /                                                                                                                                                                                               |
| 14: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              | /          | /           | /                                                                                                                                                                                               |

#### 9.4.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. The left channel sample data is first and then the right channel sample. |

#### 9.4.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         | <p>RX_CNT<br/>RX Sample Counter<br/>The audio sample number of writing into RXFIFO. 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> |

#### 9.4.6.13. 0x004C ADC Debug Register(Default Value : 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: AC_ADC_DG_REG                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:25          | /          | /           | /                                                                                                  |
| 24             | R/W        | 0x0         | <p>AD_SWP<br/>ADC output channel swap enable (for digital filter)<br/>0: disable<br/>1: enable</p> |
| 23:0           | /          | /           | /                                                                                                  |

#### 9.4.6.14. 0x00F0 DAC DAP Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00F0 |            |             | Register Name: AC_DAC_DAP_CTR                                          |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31             | R/W        | 0x0         | <p>DDAP_EN<br/>DAP for DRC Enable<br/>0: Bypass<br/>1: Enable</p>      |
| 30             | /          | /           | /                                                                      |
| 29             | R/W        | 0x0         | <p>DDAP_DRC_EN<br/>DRC enable control<br/>0: Disable<br/>1: Enable</p> |
| 28             | R/W        | 0x0         | <p>DDAP_HPF_EN<br/>HPF enable control<br/>0: Disable<br/>1: Enable</p> |
| 27:0           | /          | /           | /                                                                      |

#### 9.4.6.15. 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(adjust position, and two DRC use the same parameter)<br>DAP for ADC enable<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:0           | /          | /           | /                                                                                                              |

#### 9.4.6.16. 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        | HPF coefficient setting and the data is 3.24 format. |

#### 9.4.6.17. 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      | HPF coefficient setting and the data is 3.24 format. |

#### 9.4.6.18. 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          | 0x0         | DRC delay buffer data output state when drc delay function is enabled and the drc funciton is disabled. After disabled drc function and this bit goes to 0, the user should write the drc delay function bit to 0. |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: Not completed<br>1: Completed                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14:10 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13:8  | R/W | 0x0 | <p>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&lt;6'h30;<br/>         When the delay function is disabled, the signal delay time is unused.</p>                                                                                                             |
| 7     | R/W | 0x1 | <p>The delay buffer use or not when the drc is disabled and the drc buffer data output completely.<br/>         0: Don't use the buffer<br/>         1: Use the buffer</p>                                                                                                                                                                                                                                                                                                                    |
| 6     | R/W | 0x0 | <p>DRC gain max limit enable<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                               |
| 5     | R/W | 0x0 | <p>DRC gain min limit enable<br/>         When this function is enabled, it will overwrite the noise detect function.<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                      |
| 4     | R/W | 0x0 | <p>Control the drc to detect noise when ET enable<br/>         0: Disable<br/>         1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                          |
| 3     | R/W | 0x0 | <p>Signal function select<br/>         0: RMS filter<br/>         1: Peak filter<br/>         When signal function selects Peak filter, the RMS parameter is unused.<br/>         (AC_DRC_LRMASHAT/AC_DRC_LRMSLAT/AC_DRC_LRMASHAT/AC_DRC_LRMSLAT)<br/>         When signal function selects RMS filter, the Peak filter parameter is unused.<br/>         (AC_DRC_LPFHAT/AC_DRC_LPFLAT/AC_DRC_RPFHAT/AC_DRC_RPFLAT<br/>         /AC_DRC_LPFHRT/AC_DRC_LPFLRT/AC_DRC_RPFHRT/AC_DRC_RPFLRT)</p> |
| 2     | R/W | 0x0 | <p>Delay function enable<br/>         0: Disable<br/>         1: Enable<br/>         When the bit is disabled, the signal delay time is unused.</p>                                                                                                                                                                                                                                                                                                                                           |
| 1     | R/W | 0x0 | <p>DRC LT enable<br/>         0: Disable<br/>         1: Enable<br/>         When the bit is disabled, KI and OPL parameter is unused.</p>                                                                                                                                                                                                                                                                                                                                                    |
| 0     | R/W | 0x0 | <p>DRC ET enable<br/>         0: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

|  |  |  |                                                                        |
|--|--|--|------------------------------------------------------------------------|
|  |  |  | 1: Enable<br>When the bit is disabled, Ke and OPE parameter is unused. |
|--|--|--|------------------------------------------------------------------------|

#### 9.4.6.19. 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      | The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 9.4.6.20. 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      | The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 9.4.6.21. 0x0118 DAC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0118 |            |             | Register Name: AC_DAC_DRC_LPFLAT                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                  |
| 15:0           | R/W        | 0x77BF      | The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 9.4.6.22. 0x011C DAC 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      | The left peak filter release time parameter setting, which is determined by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

**9.4.6.23. 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      | The left peak filter release time parameter setting, which is determined by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

**9.4.6.24. 0x012C DAC 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      | The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

**9.4.6.25. 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      | The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

**9.4.6.26. 0x013C DAC 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      | The compressor threshold setting, which is set by the equation that CTin = -CT/6.0206. The format is 8.24 (The default value is -40dB) |

**9.4.6.27. 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 | The compressor threshold setting, which is set by the equation that $CTin = -CT/6.0206$ . The format is 8.24 (The default value is -40dB) |
|------|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------|

#### 9.4.6.28. 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      | The slope of the compressor, which is determined 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) |

#### 9.4.6.29. 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      | The slope of the compressor, which is determined 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) |

#### 9.4.6.30. 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      | The output of the compressor, which is determined by the equation $-OPC/6.0206$ . The format is 8.24 (The default value is -40dB) |

#### 9.4.6.31. 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      | The output of the compressor, which is determined by the equation $OPC/6.0206$ . The format is 8.24 (The default value is -40dB) |

#### 9.4.6.32. 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      | The limiter threshold setting, which is set by the equation that $LTin = -LT/6.0206$ , The format is 8.24. (The default value is -10dB) |

#### 9.4.6.33. 0x0158 DAC DRC Limiter Threshold Low Setting Register(Default Value: 0x0000\_34F0)

| Offset: 0x0158 |            |             | Register Name: AC_DAC_DRC_LLT                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                       |
| 15:0           | R/W        | 0x34F0      | The limiter threshold setting, which is set by the equation that $LTin = -LT/6.0206$ . The format is 8.24. (The default value is -10dB) |

#### 9.4.6.34. 0x015C DAC DRC Limiter Slope High Setting Register(Default Value: 0x0000\_0005)

| Offset: 0x015C |            |             | Register Name: AC_DAC_DRC_HKI                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                                  |
| 15:0           | R/W        | 0x0005      | The slope of the limiter, which is determined by the equation that $KI = 1/R$ , there, R is the ratio of the limiter, which always is interger. The format is 8.24. (The default value is <50 :1>) |

#### 9.4.6.35. 0x0160 DAC DRC Limiter Slope Low Setting Register(Default Value: 0x0000\_1EB8)

| Offset: 0x0160 |            |             | Register Name: AC_DAC_DRC_LKI                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                                  |
| 15:0           | R/W        | 0x1EB8      | The slope of the limiter, which is determined by the equation that $KI = 1/R$ , there, R is the ratio of the limiter, which always is interger. The format is 8.24. (The default value is <50 :1>) |

#### 9.4.6.36. 0x0164 DAC DRC Limiter High Output at Limiter Threshold Register(Default Value: 0x0000\_FBD8)

| Offset: 0x0164 |            |             | Register Name: AC_DAC_DRC_HOPL                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:16          | /          | /           | /                                                                             |
| 15:0           | R/W        | 0xFBDB8     | The output of the limiter, which is determined by equation $OPT/6.0206$ . The |

|  |  |  |                                             |
|--|--|--|---------------------------------------------|
|  |  |  | format is 8.24 (The default value is -25dB) |
|--|--|--|---------------------------------------------|

#### 9.4.6.37. 0x0168 DAC DRC Limiter Low Output at Limiter Threshold Register(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      | The output of the limiter, which is determined by equation OPT/6.0206. The format is 8.24 (The default value is -25dB) |

#### 9.4.6.38. 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      | The expander threshold setting, which is set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70dB) |

#### 9.4.6.39. 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      | The expander threshold setting, which is set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70dB) |

#### 9.4.6.40. 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:14          | /          | /           | /                                                                                                                                                                                                                              |
| 13:0           | R/W        | 0x0500      | The slope of the expander, which is determined by the equation that Ke = 1/R, there, R is the ratio of the expander, which always is interger and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 9.4.6.41. 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 | The slope of the expander, which is determined by the equation that $K_e = 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>) |

#### 9.4.6.42. 0x017C DAC DRC Expander High Output at Expander Threshold Register(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      | The output of the expander, which is determined by equation OPE/6.0206. The format is 8.24. (The default value is -70dB) |

#### 9.4.6.43. 0x0180 DAC DRC Expander Low Output at Expander Threshold Register(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      | The output of the expander, which is determined by equation OPE/6.0206. The format is 8.24. (The default value is -70dB) |

#### 9.4.6.44. 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      | The slope of the linear, which is determined 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>) |

#### 9.4.6.45. 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          | /          | /           | /                                                                                                                                                                                               |
| 15:0           | R/W        | 0x0000      | The slope of the linear, which is determined 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>) |

**9.4.6.46. 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      | The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 5ms) |

**9.4.6.47. 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      | The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 5ms) |

**9.4.6.48. 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      | The gain smooth filter release time parameter setting, which is determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

**9.4.6.49. 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      | The gain smooth filter release time parameter setting, which is determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

**9.4.6.50. 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 | The max gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

#### 9.4.6.51. 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      | The max gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

#### 9.4.6.52. 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      | The min gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB (The default value is -40dB) |

#### 9.4.6.53. 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      | The min gain setting, which is determined by equation MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB. (The default value is -40dB) |

#### 9.4.6.54. 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      | The gain smooth filter release and attack time parameter setting in expander region, which are determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 30ms) |

#### 9.4.6.55. 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      | The gain smooth filter release and attack time parameter setting in expander region, which are determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 30ms) |

#### 9.4.6.56. 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       | The gain of the hpf coefficient setting which format is 3.24.(gain = 1) |

#### 9.4.6.57. 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      | The gain of the hpf coefficient setting which format is 3.24.(gain = 1) |

#### 9.4.6.58. 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        | HPF coefficient setting and the data is 3.24 format. |

#### 9.4.6.59. 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      | HPF coefficient setting and the data is 3.24 format. |

**9.4.6.60. 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         | DRC delay buffer data output state when drc delay function is enabled and the drc funciton is disabled. After disabled drc function and this bit goes to 0, the user should write the drc delay function bit to 0.<br>0: Not completed<br>1: Completed                                                                                                                                                   |
| 14:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13:8           | R/W        | 0x0         | 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 disabled, the signal delay time is unused.                                                                                                                            |
| 7              | R/W        | 0x1         | The delay buffer use or not when the drc is disabled and the drc buffer data output completely.<br>0: Don't use the buffer<br>1: Use the buffer                                                                                                                                                                                                                                                          |
| 6              | R/W        | 0x0         | DRC gain max limit enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                     |
| 5              | R/W        | 0x0         | DRC gain min limit enable.<br>When this fuction is enabled, it will overwrite the noise detect funciton.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0x0         | Control the drc to detect noise when ET is enabled<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                            |
| 3              | R/W        | 0x0         | Signal function select<br>0: RMS filter<br>1: Peak filter<br>When signal function selects Peak filter, the RMS parameter is unused.<br>(AC_DRC_LRMSHAT/AC_DRC_LRMSLAT/AC_DRC_LRMSHAT/AC_DRC_LRMSLAT )<br>When signal function selects 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         | Delay function enable                                                                                                                                                                                                                                                                                                                                                                                    |

|   |     |     |                                                                                                       |
|---|-----|-----|-------------------------------------------------------------------------------------------------------|
|   |     |     | 0: Disable<br>1: Enable<br>When the bit is disabled, the signal delay time is unused.                 |
| 1 | R/W | 0x0 | DRC LT enable<br>0: Disable<br>1: Enable<br>When the bit is disabled, KI and OPL parameter is unused. |
| 0 | R/W | 0x0 | DRC ET enable<br>0: Disable<br>1: Enable<br>When the bit is disabled, Ke and OPE parameter is unused. |

#### 9.4.6.61. 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      | The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 9.4.6.62. 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      | The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/ta). The format is 3.24. (The default value is 1ms) |

#### 9.4.6.63. 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      | The left peak filter release time parameter setting, which is determined by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

**9.4.6.64. 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      | The left peak filter release time parameter setting, which is determined by the equation that RT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100ms) |

**9.4.6.65. 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      | The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

**9.4.6.66. 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      | The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tav). The format is 3.24. (The default value is 10ms) |

**9.4.6.67. 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      | The compressor threshold setting, which is set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40dB) |

**9.4.6.68. 0x0240 ADC DRC Compressor Slope High Setting Register(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 | The compressor threshold setting, which is set by the equation that $CTin = -CT/6.0206$ . The format is 8.24. (The default value is -40dB) |
|------|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------|

#### 9.4.6.69. 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      | The slope of the compressor which is determined 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>) |

#### 9.4.6.70. 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      | The slope of the compressor, which is determined 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>) |

#### 9.4.6.71. 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      | The output of the compressor, which is determined by the equation $-OPC/6.0206$ . The format is 8.24. (The default value is -40dB) |

#### 9.4.6.72. 0x0250 ADC DRC Compressor Low Output at Compressor Threshold Register(Default Value: 0x0000\_2C3F)

| Offset: 0x0250 |            |             | Register Name: AC_ADC_DRC_LOPC                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                 |
| 15:0           | R/W        | 0x2C3F      | The output of the compressor, which is determined by the equation $OPC/6.0206$ . The format is 8.24. (The default value is -40dB) |

#### 9.4.6.73. 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      | The limiter threshold setting, which is set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10dB) |

#### 9.4.6.74. 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      | The limiter threshold setting, which is set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10dB) |

#### 9.4.6.75. 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      | The slope of the limiter, which is determined by the equation that KI = 1/R, there, R is the ratio of the limiter, which always is interger. The format is 8.24. (The default value is <50 :1>) |

#### 9.4.6.76. 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      | The slope of the limiter, which is determined by the equation that KI = 1/R, there, R is the ratio of the limiter, which always is interger. The format is 8.24. (The default value is <50 :1>) |

#### 9.4.6.77. 0x0264 ADC DRC Limiter High Output at Limiter Threshold Register(Default Value: 0x0000\_FBD8)

| Offset: 0x0264 |            |             | Register Name: AC_ADC_DRC_HOPL                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:16          | /          | /           | /                                                                          |
| 15:0           | R/W        | 0xFBDB8     | The output of the limiter, which is determined by equation OPT/6.0206. The |

|  |  |  |                                              |
|--|--|--|----------------------------------------------|
|  |  |  | format is 8.24. (The default value is -25dB) |
|--|--|--|----------------------------------------------|

#### 9.4.6.78. 0x0268 ADC DRC Limiter Low Output at Limiter Threshold Register(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      | The output of the limiter which is determined by equation OPT/6.0206. The format is 8.24. (The default value is -25dB) |

#### 9.4.6.79. 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      | The expander threshold setting, which is set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70dB) |

#### 9.4.6.80. 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      | The expander threshold setting, which is set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70dB) |

#### 9.4.6.81. 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                                                                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                                                                              |
| 15:0           | R/W        | 0x0500      | The slope of the expander, which is determined by the equation that Ke = 1/R, there, R is the ratio of the expander, which always is interger and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 9.4.6.82. 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 | The slope of the expander, which is determined by the equation that $K_e = 1/R$ , there, R is the ratio of the expander, which always is interger and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 9.4.6.83. 0x027C ADC DRC Expander High Output at Expander Threshold Register(Default Value:0x0000\_F45F)

| Offset: 0x027C |            |             | Register Name: AC_ADC_DRC_HOPE                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                           |
| 15:0           | R/W        | 0xF45F      | The output of the expander, which is determined by equation $OPE/6.0206$ . The format is 8.24. (The default value is -70dB) |

#### 9.4.6.84. 0x0280 ADC DRC Expander Low Output at Expander Threshold Register(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      | The output of the expander, which is determined by equation $OPE/6.0206$ . The format is 8.24. (The default value is -70dB) |

#### 9.4.6.85. 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      | The slope of the linear, which is determined by the equation that $K_n = 1/R$ , there, R is the ratio of the linear, which always is interger. The format is 8.24. (The default value is <1:1>) |

#### 9.4.6.86. 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      | The slope of the linear, which is determined by the equation that $K_n = 1/R$ , there, R is the ratio of the linear, which always is interger. The format is 8.24. (The default value is <1:1>) |

**9.4.6.87. 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      | The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 5ms) |

**9.4.6.88. 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      | The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 5ms) |

**9.4.6.89. 0x0294 ADC DRC Smooth Filter Gain High Release Time Coef Register(Default Value: 0x0000\_0000)**

| Offset: 0x0294 |            |             | Register Name: AC_ADC_DRC_SFVRT                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:11          | /          | /           | /                                                                                                                                                                       |
| 10:0           | R/W        | 0x0000      | The gain smooth filter release time parameter setting, which is determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

**9.4.6.90. 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      | The gain smooth filter release time parameter setting, which is determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 200ms) |

**9.4.6.91. 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 | The max gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

#### 9.4.6.92. 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      | The max gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -20dB < MXG < 30dB (The default value is -10dB) |

#### 9.4.6.93. 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      | The min gain setting, which is determined by equation MXG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB (The default value is -40dB) |

#### 9.4.6.94. 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      | The min gain setting, which is determined by equation MNG/6.0206. The format is 8.24 and must -60dB ≤ MNG ≤ -40dB (The default value is -40dB) |

#### 9.4.6.95. 0x02AC ADC DAP 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      | The gain smooth filter release and attack time parameter setting in expander region, which is determined by the equation that RT = 1-exp(-2.2Ts/tr). The format is 3.24. (The default value is 30ms) |

#### 9.4.6.96. 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      | The gain smooth filter release and attack time parameter setting in expander region, which is determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 30ms) |

#### 9.4.6.97. 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       | The gain of the hpf coefficient setting, which format is 3.24.(gain = 1) |

#### 9.4.6.98. 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      | The gain of the hpf coefficient setting, which format is 3.24.(gain = 1) |

#### 9.4.6.99. 0x0300 ADCL Analog Control Register(Default Value: 0x000C\_0055)

| Default:0x0300 |            |             | Register Name: ADCL_REG                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                               |
| 31             | R/W        | 0x0         | MIC1AMPEN and ADCLEN<br>MIC1 Boost AMP Enable and ADCL Channel Enable<br>0: Disable<br>1: Enable                                                                                                                                                                          |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                         |
| 29             | R/W        | 0x0         | Dither Reset<br>0: New dither off<br>1: New dither on                                                                                                                                                                                                                     |
| 28:20          | /          | /           | /                                                                                                                                                                                                                                                                         |
| 19:18          | R/W        | 0x3         | PGA_CTRL_RCM<br>PGA Common Mode Input Impedance Control for MIC-IN (The AC coupling capacitance of MIC-IN is 100 nF. And the AC coupling capacitor combined with common-mode input resistor to form high-pass filter, the corresponding cut-off frequency is 20 Hz~80 Hz) |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 00: 100 kΩ<br>01: 75 kΩ<br>10: 50 kΩ<br>11: 25 kΩ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17:16 | R/W | 0x0 | PGA_IN_VCM_CTRL<br>High gain microphone input common mode voltage control(The field is the common-mode level control of MIC-IN when the gain is greater than or equal to 8 dB)<br>00 : 900 mV<br>01 : 800 mV<br>10 : 750 mV<br>11 : 700 mV                                                                                                                                                                                                                                                                                           |
| 15:13 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12:8  | R/W | 0x0 | PGA_GAIN_CTRL<br>PGA Gain Setting Control for MICIN<br>0 : 0 dB      16 : 21 dB<br>1 : 6 dB      17 : 22 dB<br>2 : 6 dB      18 : 23 dB<br>3 : 6 dB      19 : 24 dB<br>4 : 9 dB      20 : 25 dB<br>5 : 10 dB      21 : 26 dB<br>6 : 11 dB      22 : 27 dB<br>7 : 12 dB      23 : 28 dB<br>8 : 13 dB      24 : 29 dB<br>9 : 14 dB      25 : 30 dB<br>10 : 15 dB      26 : 31 dB<br>11 : 16 dB      27 : 32 dB<br>12 : 17 dB      28 : 33 dB<br>13 : 18 dB      29 : 34 dB<br>14 : 19 dB      30 : 35 dB<br>15 : 20 dB      31 : 36 dB |
| 7:6   | R/W | 0x1 | IOPAAFL<br>ADCL OP AAF Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5:4   | R/W | 0x1 | IOPSDML1<br>ADCL OP SDM Bias Current Select1<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:2   | R/W | 0x1 | IOPSDML2<br>ADCL OP SDM Bias Current Select2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

|     |     |     |                                                                                          |
|-----|-----|-----|------------------------------------------------------------------------------------------|
|     |     |     | 00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                             |
| 1:0 | R/W | 0x1 | IOPMICL<br>PGA OPMIC Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA |

#### 9.4.6.100. 0x0304 ADCR Analog Control Register(Default Value: 0x000C\_0055)

| Default:0x0304 |            |             | Register Name: ADCR_REG                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 31             | R/W        | 0x0         | MIC2AMPEN and ADCREN<br>MIC2 Boost AMP Enable and ADCR Channel Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                 |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                                                                                |
| 29             | R/W        | 0x0         | Dither Reset<br>0: New dither off<br>1: New dither on                                                                                                                                                                                                                                                                            |
| 28:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                                |
| 19:18          | R/W        | 0x3         | PGA_CTRL_RCM<br>PGA Common Mode Input Impedance Control for MIC-IN(The AC coupling capacitance of MIC-IN is 100nF. And the AC coupling capacitor combined with common-mode input resistor to form high-pass filter, the corresponding cut-off frequency is 20 Hz~80 Hz)<br>00 : 100 kΩ<br>01 : 75 kΩ<br>10 : 50 kΩ<br>11 : 25 kΩ |
| 17:16          | R/W        | 0x0         | PGA_IN_VCM_CTRL<br>High gain microphone input common mode voltage control(The field is the common-mode level control of MIC-IN when the gain is greater than or equal to 8 dB)<br>00 : 900 mV<br>01 : 800 mV<br>10 : 750 mV<br>11 : 700 mV                                                                                       |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                |
| 12:8           | R/W        | 0x0         | PGA_GAIN_CTRL<br>PGA Gain Setting Control for MICIN                                                                                                                                                                                                                                                                              |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0 : 0 dB      16 : 21 dB<br>1 : 6 dB      17 : 22 dB<br>2 : 6 dB      18 : 23 dB<br>3 : 6 dB      19 : 24 dB<br>4 : 9 dB      20 : 25 dB<br>5 : 10 dB     21 : 26 dB<br>6 : 11 dB     22 : 27 dB<br>7 : 12 dB     23 : 28 dB<br>8 : 13 dB     24 : 29 dB<br>9 : 14 dB     25 : 30 dB<br>10 : 15 dB    26 : 31 dB<br>11 : 16 dB    27 : 32 dB<br>12 : 17 dB    28 : 33 dB<br>13 : 18 dB    29 : 34 dB<br>14 : 19 dB    30 : 35 dB<br>15 : 20 dB    31 : 36 dB |
| 7:6 | R/W | 0x1 | <b>IOPAAFR</b><br>ADCR OP AAF Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                            |
| 5:4 | R/W | 0x1 | <b>IOPSDMR1</b><br>ADCR OP SDM Bias Current Select1<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                          |
| 3:2 | R/W | 0x1 | <b>IOPSDMR2</b><br>ADCR OP SDM Bias Current Select2<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                          |
| 1:0 | R/W | 0x1 | <b>IOPMICR</b><br>PGA OPMIC Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                                                                                                                                                                                                                                                                                                                              |

#### 9.4.6.101. 0x0310 DAC Analog Control Register(Default Value: 0x0015\_0000)

| Offset: 0x0310 | Register Name: DAC_REG |
|----------------|------------------------|
|----------------|------------------------|

| <b>Bit</b> | <b>Read/Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                   |
|------------|-------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31         | R/W               | 0x0                | CURRENT_TEST_SELECT<br>Internal Current Sink Test Enable (from LINEOUTLP pin)<br>0: Normal<br>1: For Debug                           |
| 30:28      | R/W               | 0x0                | HEADPHONE_GAIN<br>000: -0 dB<br>001: -6 dB<br>010: -12 dB<br>011: -18 dB<br>100: -24 dB<br>101: -30 dB<br>110: -36 dB<br>111: -42 dB |
| 27:26      | /                 | /                  | /                                                                                                                                    |
| 25:24      | R/W               | 0x0                | CPLDO_VOLTAGE<br>00: 0.9 V<br>01: 1.0 V<br>10: 1.1 V<br>11: 1.2 V                                                                    |
| 23:22      | R/W               | 0x0                | OPDRV_CUR.<br>OPDRV output stage current setting<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                     |
| 21:20      | R/W               | 0x1                | IOPVRS<br>VRA2 Buffer OP Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                         |
| 19:18      | R/W               | 0x1                | ILINEOUTAMPS<br>LINEOUTL/R AMP Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                   |
| 17:16      | R/W               | 0x1                | IOPDACS<br>OPDAC Bias Current Select<br>00: 7 uA<br>01: 8 uA<br>10: 9 uA<br>11: 10 uA                                                |
| 15         | R/W               | 0x0                | DACLEN                                                                                                                               |

|      |     |     |                                                                                                                                |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | DACL Enable<br>0: Disable<br>1: Enable                                                                                         |
| 14   | R/W | 0x0 | DACREN<br>DACP 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:7 | /   | /   | /                                                                                                                              |
| 6    | R/W | 0x0 | LINEOUTLDIFFEN<br>Left Channel LINEOUT Output Control<br>0: Single-End<br>1: Differential                                      |
| 5    | /   | /   | /                                                                                                                              |
| 4:0  | R/W | 0x0 | LINEOUT Volume Control, Total 30 level from 0x1F to 0x02 with the volume 0dB to -43.5dB, -1.5dB/step, mute when 00000 & 00001. |

#### 9.4.6.102. 0x0318 MICBIAS Analog Control Register(Default Value: 0x4000\_3030)

| Offset:0x0318 |            |             | Register Name: MICBIAS_REG                                                                                      |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                     |
| 31            | /          | /           | /                                                                                                               |
| 30:28         | R/W        | 0x4         | SELDETADCFS<br>Select sample interval of the ADC sample<br>000: 2 ms<br>...<br>100: 32 ms<br>...<br>111: 256 ms |
| 27:26         | R/W        | 0x0         | SELDETADCDB<br>Select debounce time when jack removal<br>00: 128 ms<br>01: 256 ms<br>10: 512 ms<br>11: 1024 ms  |
| 25:24         | R/W        | 0x0         | SELDETADCBF<br>Select the time to enable HBIAS before micadc work                                               |

|       |     |     |                                                                                                                                   |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 00: 2 ms<br>01: 4 ms<br>10: 8 ms<br>11: 16 ms                                                                                     |
| 23    | R/W | 0x0 | JACKDETEN<br>Jack detect enable<br>0: Disable<br>1: Enable                                                                        |
| 22:21 | R/W | 0x0 | SELDETADCDY<br>Select the delay time to pull low the micdet when jack removal<br>00: 0.5 ms<br>01: 1 ms<br>10: 1.5 ms<br>11: 2 ms |
| 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.88 V<br>01: 2.09 V<br>10: 2.33 V<br>11: 2.55 V                                 |
| 12    | R/W | 0x1 | HMIC BIAS chopper enable<br>0: Disable<br>1: Enable                                                                               |
| 11:10 | R/W | 0x0 | HMICBIAS chopper clock select<br>00: 250 kHz<br>01: 500 kHz                                                                       |

|     |     |     |                                                                                                   |
|-----|-----|-----|---------------------------------------------------------------------------------------------------|
|     |     |     | 10: 1 MHz<br>11: 2 MHz                                                                            |
| 9:8 | /   | /   | /                                                                                                 |
| 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.88 V<br>01: 2.09 V<br>10: 2.33 V<br>11: 2.55 V |
| 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: 1 MHz<br>11: 2 MHz            |
| 1:0 | /   | /   | /                                                                                                 |

#### 9.4.6.103. 0x0320 BIAS Analog Control Register(Default Value: 0x0000\_0080)

| Offset:0x0320 |            |             | Register Name: BIAS_REG                                                                                                                                         |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:8          | /          | /           | /                                                                                                                                                               |
| 7:0           | R/W        | 0x80        | BIASDATA<br>Bias Current Register Setting Data<br><b>Note: The register is not controlled by the audio codec module, but is controlled by system bus reset.</b> |

#### 9.4.6.104. 0x0324 Headphone Analog Control Register(Default Value: 0x8080\_0C44)

| Offset: 0x0324 |            |             | Register Name: HP_REG                                    |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | 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                                                  |

|       |     |     |                                                                                                               |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------|
|       |     |     | Right & Left Headphone PA Enable<br>0: Disable<br>1: Enable                                                   |
| 14:12 | /   | /   | /                                                                                                             |
| 11    | R/W | 0x1 | HPINPUTENABLE<br>When this bit is written to 0, the input stage of headphone disabled.                        |
| 10    | R/W | 0x1 | HPOUTPUTENABLE<br>When this bit is written to 0, the output stage of headphone disabled.                      |
| 9:8   | R/W | 0x0 | HPPA_DEL<br>Headphone delay time when start up<br>00: 4 ms<br>01: 8 ms<br>10: 16 ms<br>11: 32 ms              |
| 7:6   | R/W | 0x1 | CP_CLKS<br>Charge pump clock select<br>00: 250 kHz<br>01: 330 kHz<br>10: 400 kHz<br>11: 500 kHz               |
| 5     | R/W | 0x0 | HPCALIMODE<br>HEADPHONE calibration equilibration mode select<br>0: equilibration mode<br>1: no equilibration |
| 4     | R/W | 0x0 | HPCALVERIFY<br>HEADPHONE calibration in verify mode enable<br>0: Disable<br>1: Enable                         |
| 3     | R/W | 0x0 | HPCALIFIRST<br>When this bit is written to 1, HEADPHONE calibrates once before enable                         |
| 2:0   | R/W | 0x4 | HPCALICKS<br>HEADPHONE calibration clock frequency select<br>000: 4<br>...<br>100: 64<br>...<br>111: 512      |

#### 9.4.6.105. 0x0328 HMIC Control Register(Default Value: 0x0000\_0008)

| Offset: 0x0328 |            |             | Register Name: HMIC_CTRL |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:23          | /          | /           | /                        |

|       |     |     |                                                                                                                                                                                                                                  |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22:21 | R/W | 0x0 | HMIC_SAMPLE_SELECT<br>Down Sample Setting Select<br>00: Down by 1, 128 Hz<br>01: Down by 2, 64 Hz<br>10: Down by 4, 32 Hz<br>11: Down by 8, 16 Hz                                                                                |
| 20:16 | R/W | 0x0 | MDATA_Threshold<br>The threshold of MIC_DET pending<br>When not setting HMIC_M, and the deviation between the current obtained value and the threshold exceeds MDATA_Threshold_Debounce at twice time, the interrupt is pending. |
| 15:14 | R/W | 0x0 | HMIC_SF<br>HMIC Smooth Filter Setting<br>The compare value of MIC interrupt is the value after Smooth Filter.<br>00: by pass<br>01: $(x1+x2)/2$<br>10: $(x1+x2+x3+x4)/4$<br>11: $(x1+x2+x3+x4+x5+x6+x7+x8)/8$                    |
| 13:10 | R/W | 0x0 | HMIC_M<br>Debounce when the MIC Key down or up<br>0000: 1 sample data<br>0001: 2 sample data<br>...<br>1111: 16 sample data                                                                                                      |
| 9:6   | R/W | 0x0 | HMIC_N<br>Debounce when earphone plug in or pull out<br>125 ms~2 s<br>0000: 125 ms<br>0001: 250 ms<br>...<br>1111: 2 s                                                                                                           |
| 5:3   | R/W | 0x1 | MDATA_Threshold_Debounce<br>000: 0<br>001: 1<br>010: 2<br>011: 3<br>100: 4<br>101: 5<br>110: 6<br>111: 7                                                                                                                         |
| 2     | R/W | 0x0 | JACK_OUT_IRQ_EN<br>MIC Detect Interrupt Set<br>0: disable<br>1: enable                                                                                                                                                           |
| 1     | R/W | 0x0 | JACK_IN_IRQ_EN                                                                                                                                                                                                                   |

|   |     |     |                                                                       |
|---|-----|-----|-----------------------------------------------------------------------|
|   |     |     | MIC Detect Interrupt Set<br>0: disable<br>1: enable                   |
| 0 | R/W | 0x0 | MIC_DET_IRQ_EN<br>MIC Detect Interrupt Set<br>0: disable<br>1: enable |

#### 9.4.6.106. 0x032C HMIC Status Register(Default Value: 0x0000\_6000)

| Offset: 0x032C |            |             | Register Name: HMIC_STS                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | 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                                                                                                       |

# Contents

|                                                               |     |
|---------------------------------------------------------------|-----|
| Chapter 10 Interfaces.....                                    | 705 |
| 10.1. TWI.....                                                | 705 |
| 10.1.1. Overview .....                                        | 705 |
| 10.1.2. Block Diagram .....                                   | 705 |
| 10.1.3. Operations and Functional Descriptions .....          | 706 |
| 10.1.4. Programming Guidelines.....                           | 710 |
| 10.1.5. Register List .....                                   | 714 |
| 10.1.6. Register Description .....                            | 715 |
| 10.2. UART.....                                               | 726 |
| 10.2.1. Overview .....                                        | 726 |
| 10.2.2. Block Diagram .....                                   | 726 |
| 10.2.3. Operations and Functional Descriptions .....          | 727 |
| 10.2.4. Programming Guidelines.....                           | 732 |
| 10.2.5. Register List .....                                   | 736 |
| 10.2.6. Register Description .....                            | 737 |
| 10.3. SPI.....                                                | 753 |
| 10.3.1. Overview .....                                        | 753 |
| 10.3.2. Block Diagram .....                                   | 753 |
| 10.3.3. Operations and Functional Descriptions .....          | 754 |
| 10.3.4. Programming Guidelines.....                           | 761 |
| 10.3.5. Register List .....                                   | 765 |
| 10.3.6. Register Description .....                            | 766 |
| 10.4. USB2.0 OTG .....                                        | 782 |
| 10.4.1. Overview .....                                        | 782 |
| 10.4.2. Block Diagram .....                                   | 782 |
| 10.4.3. Operations and Functional Descriptions .....          | 783 |
| 10.5. USB2.0 Host Controller .....                            | 785 |
| 10.5.1. Overview .....                                        | 785 |
| 10.5.2. Block Diagram .....                                   | 785 |
| 10.5.3. Operations and Functional Descriptions .....          | 786 |
| 10.5.4. USB Host Register List .....                          | 786 |
| 10.5.6. OHCI Register Description .....                       | 801 |
| 10.5.7. HCI Controller and PHY Interface Description .....    | 818 |
| 10.6. Port Controller.....                                    | 823 |
| 10.6.1. Overview .....                                        | 823 |
| 10.6.2. Block Diagram .....                                   | 823 |
| 10.6.3. Operations and Functional Descriptions .....          | 824 |
| 10.6.4. Register List .....                                   | 830 |
| 10.6.5. GPIO(PB,PC,PD,PE,PF,PG,PH) Register Description ..... | 832 |
| 10.6.6. GPIO(PL) Register Description .....                   | 920 |

|                                                       |      |
|-------------------------------------------------------|------|
| 10.7. GPADC .....                                     | 933  |
| 10.7.1. Overview .....                                | 933  |
| 10.7.2. Block Diagram .....                           | 933  |
| 10.7.3. Operations and Functional Descriptions .....  | 934  |
| 10.7.4. Programming Guidelines.....                   | 935  |
| 10.7.5. Register List .....                           | 935  |
| 10.7.6. Register Description .....                    | 936  |
| 10.8. LRADC.....                                      | 942  |
| 10.8.1. Overview .....                                | 942  |
| 10.8.2. Block Diagram .....                           | 942  |
| 10.8.3. Operations and Functional Descriptions .....  | 942  |
| 10.8.4. Programming Guidelines.....                   | 944  |
| 10.8.5. Register List .....                           | 944  |
| 10.9. CIR Receiver.....                               | 948  |
| 10.9.1. Overview .....                                | 948  |
| 10.9.2. Block Diagram .....                           | 948  |
| 10.9.3. Operations and Functional Descriptions .....  | 949  |
| 10.10. CIR Transmitter.....                           | 959  |
| 10.10.1. Overview .....                               | 959  |
| 10.10.2. Block Diagram .....                          | 959  |
| 10.10.3. Operations and Functional Descriptions ..... | 960  |
| 10.10.4. Programming Guidelines.....                  | 963  |
| 10.10.5. Register List .....                          | 963  |
| 10.10.6. Register Description .....                   | 964  |
| 10.11. PWM .....                                      | 970  |
| 10.11.1. Overview .....                               | 970  |
| 10.11.2. Block Diagram .....                          | 970  |
| 10.11.3. Operations and Functional Descriptions ..... | 971  |
| 10.11.4. Working Mode .....                           | 980  |
| 10.11.5. Register List .....                          | 981  |
| 10.11.6. Register Description .....                   | 981  |
| 10.12. LEDC .....                                     | 1000 |
| 10.12.1. Overview .....                               | 1000 |
| 10.12.2. Block Diagram .....                          | 1000 |
| 10.12.3. Operations and Functional Descriptions ..... | 1000 |
| 10.12.4. Programming Guidelines.....                  | 1004 |
| 10.12.5. Register List .....                          | 1008 |
| 10.12.6. Register Description .....                   | 1008 |
| 10.13. EMAC.....                                      | 1017 |
| 10.13.1. Overview .....                               | 1017 |
| 10.13.2. Block Diagram .....                          | 1017 |
| 10.13.3. Operations and Functional Descriptions ..... | 1018 |
| 10.13.4. Register List .....                          | 1024 |
| 10.13.5. Register Description .....                   | 1025 |

## Figures

|                                                                                    |     |
|------------------------------------------------------------------------------------|-----|
| Figure 10- 1. TWI Block Diagram.....                                               | 706 |
| Figure 10- 2. 7-bit Standard Address Write Timing.....                             | 707 |
| Figure 10- 3. 7-bit Standard Address Read Timing.....                              | 708 |
| Figure 10- 4. 10-bit Extended Address Write Timing.....                            | 708 |
| Figure 10- 5. 10-bit Extended Address Read Timing.....                             | 708 |
| Figure 10- 6. TWI Programming State Diagram .....                                  | 709 |
| Figure 10- 7. TWI Initialization Process.....                                      | 711 |
| Figure 10- 8. TWI Write Data Process .....                                         | 712 |
| Figure 10- 9. TWI Read Data Process .....                                          | 713 |
| Figure 10- 10. TWI Driver Packet Transmission Process .....                        | 714 |
| Figure 10- 11. UART Block Diagram .....                                            | 727 |
| Figure 10- 12. UART Application Diagram.....                                       | 728 |
| Figure 10- 13. UART Serial Data Format .....                                       | 728 |
| Figure 10- 14. RTS/CTS Autoflow Control Timing .....                               | 729 |
| Figure 10- 15. Serial IrDA Data Format .....                                       | 729 |
| Figure 10- 16. RS-485 Timing .....                                                 | 729 |
| Figure 10- 17. Process of UART Transmitting/Receiving Data in Interrupt Mode ..... | 734 |
| Figure 10- 18. Process of DMA Transmitting Data in DMA Mode .....                  | 736 |
| Figure 10- 19. SPI Block Diagram .....                                             | 753 |
| Figure 10- 20. SPI Application Block Diagram.....                                  | 755 |
| Figure 10- 21. SPI Phase 0 Timing Diagram.....                                     | 756 |
| Figure 10- 22. SPI Phase 1 Timing Diagram.....                                     | 756 |
| Figure 10- 23. SPI 3-Wire Mode .....                                               | 757 |
| Figure 10- 24. SPI Dual-Input/Dual-Output Mode .....                               | 758 |
| Figure 10- 25. SPI Dual I/O Mode .....                                             | 758 |
| Figure 10- 26. SPI Quad-Input/Quad-Output Mode .....                               | 759 |
| Figure 10- 27. SPI Write/Read Data in CPU Mode .....                               | 763 |
| Figure 10- 28. SPI Write/Read Data in DMA Mode.....                                | 764 |
| Figure 10- 29. USB2.0 OTG Controller Block Diagram .....                           | 783 |
| Figure 10- 30. USB2.0 OTG Controller and PHY Connection Diagram .....              | 784 |
| Figure 10- 31. USB2.0 Host Controller Block Diagram .....                          | 785 |
| Figure 10- 32. USB2.0 HOST Controller and PHY Connection Diagram.....              | 786 |
| Figure 10- 33. Port Controller Block Diagram .....                                 | 823 |
| Figure 10- 34. Pull up/down Logic.....                                             | 829 |
| Figure 10- 35. IO Buffer Strength Diagram .....                                    | 829 |
| Figure 10- 36. GPADC Block Diagram.....                                            | 933 |
| Figure 10- 37. GPADC Clock and Timing Requirement.....                             | 935 |
| Figure 10- 38. GPADC Initial Process.....                                          | 935 |
| Figure 10- 39. LRADC Block Diagram.....                                            | 942 |
| Figure 10- 40. LRADC Interrupt .....                                               | 943 |

|                                                                                |      |
|--------------------------------------------------------------------------------|------|
| Figure 10- 41. LRADC Initial Process .....                                     | 944  |
| Figure 10- 42. CIR Receiver Block Diagram .....                                | 948  |
| Figure 10- 43. CIR Receiver Clock.....                                         | 949  |
| Figure 10- 44. CIR Receiver Application Diagram.....                           | 949  |
| Figure 10- 45. NEC Protocol .....                                              | 950  |
| Figure 10- 46. Logical '0' and Logical '1' of NEC Protocol .....               | 950  |
| Figure 10- 47. ATHR Definition.....                                            | 951  |
| Figure 10- 48. ITHR Definition.....                                            | 951  |
| Figure 10- 49. NTHR Definition .....                                           | 951  |
| Figure 10- 50. APAM Definition .....                                           | 952  |
| Figure 10- 51. CIR Receiver Process .....                                      | 953  |
| Figure 10- 52. CIR_TX Block Diagram .....                                      | 960  |
| Figure 10- 53. CIR_TX Clock Description .....                                  | 961  |
| Figure 10- 54. CIR One Bit Definition .....                                    | 961  |
| Figure 10- 55. CIR Message Timing Diagram.....                                 | 962  |
| Figure 10- 56. CIR Transmitter Process .....                                   | 963  |
| Figure 10- 57. PWM Block Diagram .....                                         | 970  |
| Figure 10- 58. PWM01 Clock Controller Diagram .....                            | 971  |
| Figure 10- 59. PWM01 Output Logic Module Diagram.....                          | 972  |
| Figure 10- 60. The Period and Duty-cycle of PWM0 High Level Active State ..... | 973  |
| Figure 10- 61. The Period and Duty-cycle of PWM0 Low Level Active State .....  | 974  |
| Figure 10- 62. The Phase of PWM0 High Level Active State .....                 | 974  |
| Figure 10- 63. PWM0 Output Waveform in Pulse Mode and Cycle Mode .....         | 975  |
| Figure 10- 64. PWM01 Complementary Pair Output.....                            | 975  |
| Figure 10- 65. PWM01 Pair Waveform Before/After Insert Dead-time.....          | 976  |
| Figure 10- 66. Group 0~3 PWM Signal Output .....                               | 977  |
| Figure 10- 67. PWM01 Capture Logic Module Diagram .....                        | 978  |
| Figure 10- 68. PWM0 Channel Capture Timing.....                                | 979  |
| Figure 10- 69. LEDC Block Diagram .....                                        | 1000 |
| Figure 10- 70. LEDC Package Output Timing Diagram .....                        | 1001 |
| Figure 10- 71. LEDC 1-frame Output Timing Diagram.....                         | 1001 |
| Figure 10- 72. LEDC Input Data Structure .....                                 | 1002 |
| Figure 10- 73. LEDC Typical Circuit.....                                       | 1002 |
| Figure 10- 74. LEDC Data Input Code .....                                      | 1002 |
| Figure 10- 75. LEDC Data Transfer Mode .....                                   | 1003 |
| Figure 10- 76. LEDC Normal Configuration Process .....                         | 1005 |
| Figure 10- 77. LEDC Timeout Abnormal Processing Flow .....                     | 1006 |
| Figure 10- 78. FIFO Overflow Abnormal Processing Flow.....                     | 1007 |
| Figure 10- 79. EMAC Block Diagram .....                                        | 1018 |
| Figure 10- 80. EMAC Typical Application .....                                  | 1020 |
| Figure 10- 81. EMAC RX/TX Descriptor List.....                                 | 1020 |

## Tables

|                                                    |      |
|----------------------------------------------------|------|
| Table 10- 1. TWI External Signals .....            | 706  |
| Table 10- 2. TWI Clock Sources .....               | 707  |
| Table 10- 3. UART External Signals.....            | 727  |
| Table 10- 4. UART Clock Sources.....               | 728  |
| Table 10- 5. UART Mode Baud and Error Rates .....  | 730  |
| Table 10- 6. IrDA Mode Baud and Error Rates .....  | 730  |
| Table 10- 7. RS485 Mode Baud and Error Rates ..... | 731  |
| Table 10- 8. SPI External Signals.....             | 754  |
| Table 10- 9. SPI Clock Sources.....                | 755  |
| Table 10- 10. SPI Transmit Format.....             | 756  |
| Table 10- 11. SPI Old Sample Mode .....            | 760  |
| Table 10- 12. SPI New Sample Mode .....            | 760  |
| Table 10- 13. USB2.0 OTG External Signals.....     | 783  |
| Table 10- 14. USB2.0 HOST External Signals .....   | 786  |
| Table 10- 15. A133 Multi-function Port Table ..... | 824  |
| Table 10- 16. PB Multiplex Function Select .....   | 824  |
| Table 10- 17. PC Multiplex Function Select.....    | 824  |
| Table 10- 18. PD Multiplex Function Select .....   | 825  |
| Table 10- 19. PE Multiplex Function Select .....   | 826  |
| Table 10- 20. PF Multiplex Function Select .....   | 826  |
| Table 10- 21. PG Multiplex Function Select .....   | 826  |
| Table 10- 22. PH Multiplex Function Select .....   | 827  |
| Table 10- 23. PL Multiplex Function Select .....   | 827  |
| Table 10- 24. Port Function.....                   | 828  |
| Table 10- 25. GPADC External Signals .....         | 934  |
| Table 10- 26. GPADC Clock Sources .....            | 934  |
| Table 10- 27. LRADC External Signals.....          | 943  |
| Table 10- 28. LRADC Clock Sources.....             | 943  |
| Table 10- 29. CIR Receiver External Signals .....  | 949  |
| Table 10- 30. CIR_TX External Signals .....        | 960  |
| Table 10- 31. PWM External Signals .....           | 971  |
| Table 10- 32. LEDC External Signals .....          | 1001 |
| Table 10- 33. LEDC Clock Sources .....             | 1001 |
| Table 10- 34. EMAC Pin Mapping.....                | 1018 |
| Table 10- 35. EMAC RGMII Pin List.....             | 1019 |
| Table 10- 36. EMAC RMII Pin List .....             | 1019 |
| Table 10- 37. EMAC Clock Characteristics.....      | 1019 |

# Chapter 10 Interfaces

## 10.1. TWI

### 10.1.1. Overview

The TWI is designed as an interface between CPU host and the serial TWI bus. It can support all the standard TWI transfer, including slave and master. The communication of the 2-wire bus is carried out by a byte-wise mode based on interrupt or polled handshaking. The TWI can be operated in standard mode (100 kbit/s) or fast-mode (400 kbit/s). The 10-bit addressing mode is supported for this specified application. General call addressing is also supported in slave mode.

The TWI has the following features:

- Software-programmable for slave or master
- Supports repeated START signal
- Allows 10-bit addressing with TWI bus
- Performs arbitration and clock synchronization
- Own address and general call address detection
- Interrupt on address detection
- Supports speed up to 400 kbit/s ('fast mode')
- Allows operation from a wide range of input clock frequency
- TWI driver supports packet transmission and DMA when TWI works in master mode

### 10.1.2. Block Diagram

Figure 10-1 shows the block diagram of TWI.



Figure 10-1. TWI Block Diagram

RESET: Module reset signal

INT: Module output interrupt signal

CFG\_REG: Module configuration register in TWI

PE: Packet encoding/decoding

CCU: Module clock controller unit

### 10.1.3. Operations and Functional Descriptions

#### 10.1.3.1. External Signals

The TWI controller has 5 TWIs. Table 10-1 describes the external signals of TWI. TWI\_SCK and TWI\_SDA are bidirectional I/O, when TWI is configured as master device, TWI\_SCK is output pin; when TWI is configurable as slave device, TWI\_SCK is input pin. The unused TWI ports are used as General Purpose I/O ports. For information about General Purpose I/O ports, see **Port Controller** in chapter10.

Table 10-1. TWI External Signals

| Signal     | Description         | Type   |
|------------|---------------------|--------|
| TWI0_SCK   | TWI0 Clock Signal   | I/O,OD |
| TWI0_SDA   | TWI0 Serial Data    | I/O,OD |
| TWI1_SCK   | TWI1 Clock Signal   | I/O,OD |
| TWI1_SDA   | TWI1 Serial Data    | I/O,OD |
| TWI2_SCK   | TWI2 Clock Signal   | I/O,OD |
| TWI2_SDA   | TWI2 Serial Data    | I/O,OD |
| TWI3_SCK   | TWI3 Clock Signal   | I/O,OD |
| TWI3_SDA   | TWI3 Serial Data    | I/O,OD |
| S_TWI0_SCK | S_TWI0 Clock Signal | I/O,OD |
| S_TWI0_SDA | S_TWI0 Serial Data  | I/O,OD |
| S_TWI1_SCK | S_TWI1 Clock Signal | I/O,OD |

|            |                    |        |
|------------|--------------------|--------|
| S_TWI1_SDA | S_TWI1 Serial Data | I/O,OD |
|------------|--------------------|--------|

### 10.1.3.2. Clock Sources

Each TWI controller has a fixed clock source. Table 10-2 describes the clock source for TWI. Users can see **Clock Controller Unit(CCU)** in chapter3 for clock setting, configuration and gating information.

**Table 10- 2. TWI Clock Sources**

| Clock Sources | Description                                               |
|---------------|-----------------------------------------------------------|
| APB2_CLK      | TWI0/1/2/3 clock source, for details on APB2 refer to CCU |

After selected a proper clock, for using the TWI0/1/2/3, user must enable the gating of TWI and release the reset bit.

### 10.1.3.3. Write/Read Timing in Standard and Extended Address Mode

Figure 10-2 describes the write timing in 7-bit standard address mode.

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S: START condition

A: acknowledge(SDA LOW)

from slave to master

P: STOP condition

A: not acknowledge(SDA HIGH)

**Figure 10- 2. 7-bit Standard Address Write Timing**

Figure 10-3 describes the read timing in 7-bit standard address mode.

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S: START condition

A: acknowledge(SDA LOW)

from slave to master

Sr: RE-START condition

A: not acknowledge(SDA HIGH)

**Figure 10- 3. 7-bit Standard Address Read Timing**

Figure 10-4 describes the write timing in 10-bit extended address mode.

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte


**Figure 10- 4. 10-bit Extended Address Write Timing**

Figure 10-5 describes the read timing in 10-bit extended address mode.

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte


**Figure 10- 5. 10-bit Extended Address Read Timing**

#### 10.1.3.4. Programming State Diagram

Figure 10-6 shows the TWI programming state diagram. For the value between two states, see TWI\_STAT register in section 10.1.6.5.

M\_SEND\_S: master sends START signal;

M\_SEND\_ADDR: master sends slave address;

M\_SEND\_XADD: master sends slave extended address;

M\_SEND\_SR: master repeated start;

M\_SEND\_DATA: master sends data;

M\_SEND\_P: master sends STOP signal;

M\_RECV\_DATA: master receives data;

ARB\_LOST: Arbitration lost;

C\_IDLE: Idle;



Figure 10- 6. TWI Programming State Diagram

#### 10.1.3.5. TWI Engine Master and Slave Mode

There are four operation modes on the TWI bus. They are Master Transmit, Master Receive, Slave Transmit and Slave Receive. In general, CPU host controls TWI engine by writing command and data to its registers. TWI engine transmits an interrupt to CPU when each time a byte transfer is done or a START/STOP command is detected. The CPU host can also poll the status register for current status if the interrupt mechanism is not disabled by the CPU host.

When the CPU host wants to start a bus transfer, it initiates a bus START to enter the master mode by setting IM\_STA bit of the TWI\_CNTR register to high (before it must be low). The TWI engine will assert INT line and INT\_FLAG to indicate a completion for the START command and each consequent byte transfer. At each interrupt, the micro-processor needs to check the TWI\_STAT register for current status. A transfer has to be concluded with STOP command by setting M\_STP bit to high.

In Slave mode, the TWI engine also constantly samples the bus and look for its own slave address during addressing cycles. Once a match is found, it is addressed and interrupt the CPU host with the corresponding status. Upon request,

the CPU host should read the status, read/write TWI\_DATA data register, and set the TWI\_CNTR control register. After each byte transfer, a slave device always stop the operation of remote master by holding the next low pulse on SCL line until the microprocessor responds to the status of previous byte transfer or START command.

#### 10.1.4. Programming Guidelines

The TWI controller operates in 8-bit data format. The data on the TWI\_SDA line is always 8 bits long. At first, the TWI controller will sent a start condition. When in the addressing formats of 7-bit, TWI sends out one 8 bits message which includes 7 MSB slave address and 1 LSB read/write flag. The least significant of the salve address indicates the direction of transmission. When TWI works in 10-bit slave address mode, the operation will be divided into two steps, for details on the operation, see the register description in Section 10.1.6.1 and 10.1.6.2.

##### 10.1.4.1. Initialization

To initialize the TWI, perform the following steps:

- Step1** Configure corresponding GPIO multiplex function as TWI mode.
- Step2** For TWIx, set TWI\_BGR\_REG[TWIx\_GATING] in CCU module to 0 to close TWIx clock;
- Step3** For TWIx, set TWI\_BGR\_REG[TWIx\_RST] in CCU module to 0, then set to 1 to reset TWIx;
- Step4** For TWIx, set TWI\_BGR\_REG[TWIx\_GATING] in CCU module to 1 to open TWIx clock;
- Step5** Configure TWI\_CCR[CLK\_M] and TWI\_CCR[CLK\_N] to get the needed rate(The clock source of TWI is from APB2).
- Step6** Configure TWI\_CNTR[BUS\_EN] and TWI\_CNTR[A\_ACK], when using interrupt, set TWI\_CNTR[BUS\_EN] to 1, and register system interrupt through GIC module. In slave mode, configure TWI\_ADDR and TWI\_XADDR registers to finish TWI initialization configuration.

Figure 10-7 shows the process of TWI initialization.



Figure 10- 7. TWI Initialization Process

#### 10.1.4.2. Data Write Operation

To write data to device, perform the following steps:

**Step1** Clear TWI\_EFR register, and configure TWI\_CNTR[M\_STA] to 1 to transmit START signal.

**Step2** After START signal is transmitted, the first interrupt is triggered, then write device ID to TWI\_DATA(For 10-bit device ID, firstly write the first byte ID, secondly write the second byte ID in the next interrupt).

**Step3** Interrupt is triggered again after device ID transmission completes, write device data address to be read to TWI\_DATA(For 16-bit address, firstly write the first byte address, secondly write the second byte address).

**Step4** Interrupt is triggered after data address transmission completes, write data to be transmitted to TWI\_DATA(For consecutive write data operation, every byte transmission completion triggers interrupt, during interrupt write the next byte data to TWI\_DATA).

**Step5** After transmission completes, write TWI\_CNTR[M\_STP] to 1 to transmit STOP signal and end this write-operation.

Figure 10-8 shows the process of TWI write to device.



Figure 10- 8. TWI Write Data Process

#### 10.1.4.3. Data Read Operation

To read data from device, perform the following steps:

- Step1** Clear TWI\_EFR register, set TWI\_CNTR[A\_ACK] to 1, and configure TWI\_CNTR[M\_STA] to 1 to transmit START signal.
- Step2** After START signal is transmitted, the first interrupt is triggered, then write device ID to TWI\_DATA(For 10-bit device ID, firstly write the first byte ID, secondly write the second byte ID in the next interrupt).
- Step3** Interrupt is triggered again after device ID transmission completes, write device data address to be read to TWI\_DATA(For 16-bit address, firstly write the first byte address, secondly write the second byte address).
- Step4** Interrupt is triggered after data address transmission completes, write TWI\_CNTR[M\_STA] to 1 to transmit new START signal, and after interrupt triggers, write device ID to TWI\_DATA to start read-operation.
- Step5** After device address transmission completes, each receive completion will trigger interrupt, in turn, read TWI\_DATA to get data, when receiving the previous interrupt of the last byte data, clear TWI\_CNTR[A\_ACK] to stop acknowledge signal of the last byte.
- Step6** Write TWI\_CNTR[M\_STP] to 1 to transmit STOP signal and end this read-operation.

Figure 10-9 shows the process of TWI read from device.



Figure 10- 9. TWI Read Data Process

#### 10.1.4.4. Packet Transmission Operation

Figure 10-10 shows a software operation flow for packet transmission by TWI driver.



**Figure 10- 10. TWI Driver Packet Transmission Process**

### 10.1.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| TWI0        | 0x05002000   |
| TWI1        | 0x05002400   |
| TWI2        | 0x05002800   |
| TWI3        | 0x05002C00   |
| R_TWI0      | 0x07081400   |
| R_TWI1      | 0x07081800   |

| Register Name | Offset | Description                  |
|---------------|--------|------------------------------|
| TWI_ADDR      | 0x0000 | TWI Slave Address            |
| TWI_XADDR     | 0x0004 | TWI Extended Slave Address   |
| TWI_DATA      | 0x0008 | TWI Data Byte                |
| TWI_CNTR      | 0x000C | TWI Control Register         |
| TWI_STAT      | 0x0010 | TWI Status Register          |
| TWI_CCR       | 0x0014 | TWI Clock Control Register   |
| TWI_SRST      | 0x0018 | TWI Software Reset           |
| TWI_EFR       | 0x001C | TWI Enhance Feature Register |
| TWI_LCR       | 0x0020 | TWI Line Control Register    |
| TWI_DRV_CTRL  | 0x0200 | TWI_DRV Control Register     |

|                       |        |                                             |
|-----------------------|--------|---------------------------------------------|
| TWI_DRV_CFG           | 0x0204 | TWI_DRV Transmission Configuration Register |
| TWI_DRV_SLV           | 0x0208 | TWI_DRV Slave ID Register                   |
| TWI_DRV_FMT           | 0x020C | TWI_DRV Packet Format Register              |
| TWI_DRV_BUS_CTRL      | 0x0210 | TWI_DRV Bus Control Register                |
| TWI_DRV_INT_CTRL      | 0x0214 | TWI_DRV Interrupt Control Register          |
| TWI_DRV_DMA_CFG       | 0x0218 | TWI_DRV DMA Configure Register              |
| TWI_DRV_FIFO_CON      | 0x021C | TWI_DRV FIFO Content Register               |
| TWI_DRV_SEND_FIFO_ACC | 0x0300 | TWI_DRV Send Data FIFO Access Register      |
| TWI_DRV_RECV_FIFO_ACC | 0x0304 | TWI_DRV Receive Data FIFO Access Register   |

### 10.1.6. Register Description

#### 10.1.6.1. 0x0000 TWI Slave Address Register(Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TWI_ADDR                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:8           | /          | /           | /                                                                                                                                           |
| 7:1            | R/W        | 0x0         | SLA<br>Slave Address<br>7-bit addressing:<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0<br><br>10-bit addressing:<br>1, 1, 1, 1, 0, SLAX[9:8] |
| 0              | R/W        | 0x0         | GCE<br>General Call Address Enable<br>0: Disable<br>1: Enable                                                                               |



#### NOTE

For 7-bit addressing:

SLA6 – SLA0 is the 7-bit address of the TWI in slave mode. When the TWI receives this address after a START condition, it will generate an interrupt and enter slave mode. (SLA6 corresponds to the first bit received from the TWI bus.) If GCE is set to '1', the TWI will also recognize the general call address (00h).

For 10-bit addressing:

When the address received starts with 11110b, the TWI recognizes this as the first part of a 10-bit address and if the next two bits match ADDR[2:1] (i.e. SLAX9 and SLAX8 of the device's extended address), it sends an ACK. (The device does not generate an interrupt at this point.) If the next byte of the address matches the XADDR register (SLAX7 – SLAX0), the TWI generates an interrupt and goes into slave mode.

#### 10.1.6.2. 0x0004 TWI Extend Address Register(Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TWI_XADDR                  |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:8           | /          | /           | /                                         |
| 7:0            | R/W        | 0x0         | SLAX<br>Extend Slave Address<br>SLAX[7:0] |

#### 10.1.6.3. 0x0008 TWI Data Register(Default Value:0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TWI_DATA                       |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:8           | /          | /           | /                                             |
| 7:0            | R/W        | 0x0         | TWI_DATA<br>Data byte transmitted or received |

#### 10.1.6.4. 0x000C TWI Control Register(Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7              | R/W        | 0x0         | INT_EN<br>Interrupt Enable<br>0: The interrupt line always low<br>1: The interrupt line will go high when INT_FLAG is set.                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6              | R/W        | 0x0         | BUS_EN<br>TWI Bus Enable<br>0: The TWI bus ISDA/ISCL is ignored and the TWI Controller will not respond to any address on the bus<br>1: The TWI will respond to call to its slave address – and to the general call address if the GCE bit in the ADDR register is set.<br><b>Note: In master operation mode, this bit should be set to '1'.</b>                                                                                                                                                                                     |
| 5              | R/WAC      | 0x0         | M_STA<br>Master Mode Start<br>When M_STA is set to '1', TWI controller enters master mode and will transmit a START condition on the bus when the bus is free. If the M_STA bit is set to '1' when the TWI controller is already in master mode and one or more bytes have been transmitted, then a repeated START condition will be sent. If the M_STA bit is set to '1' when the TWI is being accessed in slave mode, the TWI will complete the data transfer in slave mode then enter master mode when the bus has been released. |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | The M_STA bit is cleared automatically after a START condition has been sent. Writing a '0' to this bit has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 4 | R/W1C | 0x0 | <p>M_STP<br/>Master Mode Stop</p> <p>If M_STP is set to '1' in master mode, a STOP condition is transmitted on the TWI bus. If the M_STP bit is set to '1' in slave mode, the TWI will indicate if a STOP condition has been received, but no STOP condition will be transmitted on the TWI bus. If both M_STA and M_STP bits are set, the TWI will first transmit the STOP condition (if in master mode) then transmit the START condition.</p> <p>The M_STP bit is cleared automatically: writing a '0' to this bit has no effect.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3 | R/W1C | 0x0 | <p>INT_FLAG<br/>Interrupt Flag</p> <p>INT_FLAG is automatically set to '1' when any of 28 (out of the possible 29) states is entered (see 'STAT Register' below). The only state that does not set INT_FLAG is state F8h. If the INT_EN bit is set, the interrupt line goes high when IFLG is set to '1'. If the TWI is operating in slave mode, data transfer is suspended when INT_FLAG is set and the low period of the TWI bus clock line (SCL) is stretched until '1' is written to INT_FLAG. The TWI clock line is then released and the interrupt line goes low.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 2 | R/W   | 0x0 | <p>A_ACK<br/>Assert Acknowledge</p> <p>When A_ACK is set to '1', an Acknowledge (low level on SDA) will be sent during the acknowledge clock pulse on the TWI bus if:</p> <ul style="list-style-type: none"> <li>(1). Either the whole of a matching 7-bit slave address or the first or the second byte of a matching 10-bit slave address has been received.</li> <li>(2). The general call address has been received and the GCE bit in the ADDR register is set to '1'.</li> <li>(3). A data byte has been received in master or slave mode.</li> </ul> <p>When A_ACK is '0', a Not Acknowledge (high level on SDA) will be sent when a data byte is received in master or slave mode.</p> <p>If A_ACK is cleared to '0' in slave transmitter mode, the byte in the DATA register is assumed to be the 'last byte'. After this byte has been transmitted, the TWI will enter state C8h then return to the idle state (status code F8h) when INT_FLAG is cleared.</p> <p>The TWI will not respond as a slave unless A_ACK is set.</p> |
| 1 | /     | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0 | R/W   | 0x0 | CLK_COUNT_MODE<br>0: scl clock high period count on oscl<br>1: scl clock high period count on iscl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## 10.1.6.5. 0x0010 TWI Status Register(Default Value:0x0000\_00F8)

| Offset: 0x0010 |            |             | Register Name: TWI_STAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:0            | R          | 0xF8        | <p>STA<br/>Status Information Byte</p> <p><b>Code Status</b></p> <ul style="list-style-type: none"> <li>0x00: Bus error</li> <li>0x08: START condition transmitted</li> <li>0x10: Repeated START condition transmitted</li> <li>0x18: Address + Write bit transmitted, ACK received</li> <li>0x20: Address + Write bit transmitted, ACK not received</li> <li>0x28: Data byte transmitted in master mode, ACK received</li> <li>0x30: Data byte transmitted in master mode, ACK not received</li> <li>0x38: Arbitration lost in address or data byte</li> <li>0x40: Address + Read bit transmitted, ACK received</li> <li>0x48: Address + Read bit transmitted, ACK not received</li> <li>0x50: Data byte received in master mode, ACK transmitted</li> <li>0x58: Data byte received in master mode, not ACK transmitted</li> <li>0x60: Slave address + Write bit received, ACK transmitted</li> <li>0x68: Arbitration lost in address as master, slave address + Write bit received, ACK transmitted</li> <li>0x70: General Call address received, ACK transmitted</li> <li>0x78: Arbitration lost in address as master, General Call address received, ACK transmitted</li> <li>0x80: Data byte received after slave address received, ACK transmitted</li> <li>0x88: Data byte received after slave address received, not ACK transmitted</li> <li>0x90: Data byte received after General Call received, ACK transmitted</li> <li>0x98: Data byte received after General Call received, not ACK transmitted</li> <li>0xA0: STOP or repeated START condition received in slave mode</li> <li>0xA8: Slave address + Read bit received, ACK transmitted</li> <li>0xB0: Arbitration lost in address as master, slave address + Read bit received, ACK transmitted</li> <li>0xB8: Data byte transmitted in slave mode, ACK received</li> <li>0xC0: Data byte transmitted in slave mode, ACK not received</li> <li>0xC8: Last byte transmitted in slave mode, ACK received</li> <li>0xD0: Second Address byte + Write bit transmitted, ACK received</li> <li>0xD8: Second Address byte + Write bit transmitted, ACK not received</li> <li>0xF8: No relevant status information, INT_FLAG=0</li> <li>Others: Reserved</li> </ul> |

#### 10.1.6.6. 0x0014 TWI Clock Register(Default Value:0x0000\_0080)

| Offset: 0x0014 |            |             | Register Name: TWI_CCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7              | R/W        | 0x1         | CLK_DUTY<br>Setting duty cycle of clock as Master<br>0: 50%<br>1: 40%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6:3            | R/W        | 0x0         | CLK_M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2:0            | R/W        | 0x0         | CLK_N<br>The TWI bus is sampled by the TWI at the frequency defined by F0:<br>$F_{amp} = F_0 = F_{in} / 2^{CLK\_N}$<br><br>The TWI OSCL output frequency, in master mode, is $F_1 / 10$ :<br>$F_1 = F_0 / (CLK\_M + 1)$<br>$F_{oscl} = F_1 / 10 = F_{in} / (2^{CLK\_N} * (CLK\_M + 1) * 10)$<br>Specially, $F_{oscl} = F_1/11$ when $CLK\_M=0$ and $CLK\_DUTY=40\%$ due to the delay of SCL sample debounce.<br>For example:<br>$F_{in} = 24 \text{ MHz (APB clock input)}$<br>For 400 kHz full speed 2Wire, $CLK\_N = 1$ , $CLK\_M=2$<br>$F_0 = 24 \text{ MHz}/2^1=12 \text{ MHz}$ , $F_1= F_0/(10*(2+1)) = 0.4 \text{ MHz}$<br><br>For 100 kHz standard speed 2Wire, $CLK\_N=1$ , $CLK\_M=11$<br>$F_0=24 \text{ MHz}/2^1=12 \text{ MHz}$ , $F_1=F_0/(10*(11+1)) = 0.1 \text{ MHz}$ |

#### 10.1.6.7. 0x0018 TWI Soft Reset Register(Default Value:0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: TWI_SRST                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:1           | /          | /           | /                                                                                                                       |
| 0              | R/WAC      | 0x0         | SOFT_RST<br>Soft Reset<br>Write '1' to this bit to reset the TWI and clear to '0' when completing Soft Reset operation. |

#### 10.1.6.8. 0x001C TWI Enhance Feature Register(Default Value:0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: TWI_EFR |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:2           | /          | /           | /                      |

|     |     |     |                                                                                                                                                                                                                                                                                            |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | R/W | 0x0 | <b>DBN</b><br>Data Byte Number Follow Read Command Control<br>00 : No data byte can be written after read command<br>01 : Only 1 byte data can be written after read command<br>10 : 2 bytes data can be written after read command<br>11 : 3 bytes data can be written after read command |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.1.6.9. 0x0020 TWI Line Control Register(Default Value:0x0000\_003A)

| Offset: 0x0020 |            |             | Register Name: TWI_LCR                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                 |
| 31:6           | /          | /           | /                                                                                                                                                                                                                           |
| 5              | R          | 0x1         | <b>SCL_STATE</b><br>Current State of TWI_SCL<br>0 : Low<br>1 : High                                                                                                                                                         |
| 4              | R          | 0x1         | <b>SDA_STATE</b><br>Current State of TWI_SDA<br>0 : Low<br>1 : High                                                                                                                                                         |
| 3              | R/W        | 0x1         | <b>SCL_CTL</b><br>TWI_SCL Line State Control Bit<br>When line control mode is enabled (bit[2] set), this bit decides the output level of TWI_SCL.<br>0 : Output low level<br>1 : Output high level                          |
| 2              | R/W        | 0x0         | <b>SCL_CTL_EN</b><br>TWI_SCL Line State Control Enable<br>When this bit is set, the state of TWI_SCL is controlled by the value of bit[3].<br>0 : Disable TWI_SCL line control mode<br>1 : Enable TWI_SCL line control mode |
| 1              | R/W        | 0x1         | <b>SDA_CTL</b><br>TWI_SDA Line State Control Bit<br>When line control mode is enabled (bit[0] set), this bit decides the output level of TWI_SDA.<br>0 : Output low level<br>1 : Output high level                          |
| 0              | R/W        | 0x0         | <b>SDA_CTL_EN</b><br>TWI_SDA Line State Control Enable<br>When this bit is set, the state of TWI_SDA is controlled by the value of bit[1].<br>0 : Disable TWI_SDA line control mode<br>1 : Enable TWI_SDA line control mode |

**10.1.6.10. 0x0200 TWI\_DRV Control Register(Default Value:0x00F8\_1000)**

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31             | R/WAC      | 0x0         | <p>START_TRAN<br/>0: Transmission idle<br/>1: Start transmission</p> <p>Automatically cleared to '0' when finished. If slave not respond for the expected status over the time defined by TIMEOUT, current transmission will stop. All format setting and data will be loaded from registers and FIFO when transmission start.</p>                                                                                                                                                                                                                                                                                                                                                                                                               |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 29             | R/W        | 0x0         | <p>RESTART_MODE<br/>0: RESTART<br/>1: STOP+START</p> <p>Define the TWI_DRV action after sending register address.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 28             | R/W        | 0x0         | <p>READ_TRAN_MODE<br/>0: send slave_id+W<br/>1: do not send slave_id+W</p> <p><b>Setting this bit to 1 if reading from a slave which register width is equal to 0.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27:24          | R          | 0x0         | <p>TRAN_RESULT<br/>0000: OK<br/>0001: FAIL<br/>Other: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23:16          | R          | 0xf8        | <p>TWI_STA<br/>0x00: bus error<br/>0x08: START condition transmitted<br/>0x10: Repeated START condition transmitted<br/>0x18: Address + Write bit transmitted, ACK received<br/>0x20: Address + Write bit transmitted, ACK not received<br/>0x28: Data byte transmitted in master mode, ACK received<br/>0x30: Data byte transmitted in master mode, ACK not received<br/>0x38: Arbitration lost in address or data byte<br/>0x40: Address + Read bit transmitted, ACK received<br/>0x48: Address + Read bit transmitted, ACK not received<br/>0x50: Data byte received in master mode, ACK received<br/>0x58: Data byte received in master mode, ACK not received<br/>0x01: Timeout when sending 9<sup>th</sup> SCL clk<br/>Other: Reserved</p> |
| 15:8           | R/W        | 0x10        | <p>TIMEOUT_N</p> <p>When sending the 9<sup>th</sup> clock, assert fail signal when slave device does not response after <math>N \cdot F_{SCL}</math> cycles. And software must do a reset to TWI_DRV module and send a stop condition to slave.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

|   |     |     |                                                                                   |
|---|-----|-----|-----------------------------------------------------------------------------------|
| 1 | R/W | 0x0 | SOFT_RESET<br>0: normal<br>1: reset                                               |
| 0 | R/W | 0x0 | TWI_DRV_EN<br>0: Module disable<br>1: Module enable (only use in TWI Master Mode) |

#### 10.1.6.11. 0x0204 TWI\_DRV Transmission Configuration Register(Default Value:0x0000\_0001)

| Offset: 0x0204 |            |             | Register Name: TWI_DRV_CFG                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:16          | R/W        | 0x0         | PKT_INTERVAL<br>Define the interval between each packet for PKT_INTERVAL $F_{SCL}$ cycles. |
| 15:0           | R/W        | 0x1         | PACKET_CNT<br>FIFO data be transmitted as PACKET_CNT packets in current format.            |

#### 10.1.6.12. 0x0208 TWI\_DRV Slave ID Register(Default Value:0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: TWI_DRV_SLV                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                        |
| 15:9           | R/W        | 0x0         | SLV_ID<br>Slave device ID<br><ul style="list-style-type: none"> <li>• 7-bit addressing<br/>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0</li> <li>• 10-bit addressing<br/>1, 1, 1, 1, 0, SLAX[9:8]</li> </ul> |
| 8              | R/W        | 0x0         | CMD<br>R/W operation to slave device<br>0: write<br>1: read                                                                                                                                              |
| 7:0            | R/W        | 0x0         | SLV_ID_X<br>SLAX[7:0], low 8 bits for slave device ID with 10-bit addressing                                                                                                                             |

#### 10.1.6.13. 0x020C TWI\_DRV Packet Format Register(Default Value:0x0001\_0001)

| Offset: 0x020C |            |             | Register Name: TWI_DRV_FMT                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:24          | /          | /           | /                                                              |
| 23:16          | R/W        | 0x1         | ADDR_BYT<br>How many bytes be sent as slave device reg address |

|      |     |     |                                                                        |
|------|-----|-----|------------------------------------------------------------------------|
|      |     |     | 0~255                                                                  |
| 15:0 | R/W | 0x1 | <b>DATA_BYTE</b><br>How many bytes be sent/received as data<br>1~65535 |

#### 10.1.6.14. 0x0210 TWI\_DRV Bus Control Register(Default Value:0x0000\_80C0)

| Offset: 0x0210 |            |             | Register Name: TWI_DRV_BUS_CTRL                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31:17          | /          | /           | /                                                                                                                                                                                          |
| 16             | W          | 0x0         | <b>CLK_COUNT_MODE</b><br>0: scl clock high period count on oscl<br>1: scl clock high period count on iscl                                                                                  |
| 15             | R/W        | 0x1         | <b>CLK_DUTY</b><br>Setting duty cycle of Clock as Master<br>0: 50%<br>1: 40%                                                                                                               |
| 14:12          | R/W        | 0x0         | <b>CLK_N</b><br>TWI_DRV bus sampling clock F0=24MHz/2^CLK_N                                                                                                                                |
| 11:8           | R/W        | 0x0         | <b>CLK_M</b><br>TWI_DRV output SCL frequency is $F_{SCL}=F1/10=(F0/(CLK\_M+1))/10$<br>Specially, $F_{oscl} = F1/11$ when CLK_M=0 and CLK_DUTY=40% due to the delay of SCL sample debounce. |
| 7              | R          | 0x1         | <b>SCL_STA</b><br>SCL current status                                                                                                                                                       |
| 6              | R          | 0x1         | <b>SDA_STA</b><br>SDA current status                                                                                                                                                       |
| 5:4            | /          | /           | /                                                                                                                                                                                          |
| 3              | R/W        | 0x0         | <b>SCL_MOV</b><br>SCL manual output value                                                                                                                                                  |
| 2              | R/W        | 0x0         | <b>SDA_MOV</b><br>SDA manual output value                                                                                                                                                  |
| 1              | R/W        | 0x0         | <b>SCL_MOE</b><br>SCL manual output en                                                                                                                                                     |
| 0              | R/W        | 0x0         | <b>SDA_MOE</b><br>SDA manual output en                                                                                                                                                     |

#### 10.1.6.15. 0x0214 TWI\_DRV Interrupt Control Register(Default Value:0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: TWI_DRV_INT_CTRL |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:18          | /          | /           | /                               |

|      |       |     |                                                                                        |
|------|-------|-----|----------------------------------------------------------------------------------------|
| 19   | R/W   | 0x0 | RX_REQ_INT_EN                                                                          |
| 18   | R/W   | 0x0 | TX_REQ_INT_EN                                                                          |
| 17   | R/W   | 0x0 | TRAN_ERR_INT_EN                                                                        |
| 16   | R/W   | 0x0 | TRAN_COM_INT_EN                                                                        |
| 15:4 | /     | /   | /                                                                                      |
| 3    | R/W1C | 0x0 | RX_REQ_PD<br>Set when the data byte number in RECV_FIFO reaches RX_TRIG                |
| 2    | R/W1C | 0x0 | TX_REQ_PD<br>Set when there is no less than DMA_TX_TRIG empty byte number in SEND_FIFO |
| 1    | R/W1C | 0x0 | TRAN_ERR_PD<br>Packet transmission failed pending                                      |
| 0    | R/W1C | 0x0 | TRAN_COM_PD<br>Packet transmission completed pending                                   |

#### 10.1.6.16. 0x0218 TWI\_DRV DMA Configure Register(Default Value:0x0010\_0010)

| Offset: 0x0218 |            |             | Register Name: TWI_DRV_DMA_CFG                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                              |
| 31:25          | /          | /           | /                                                                                                                                                                        |
| 24             | R/W        | 0x0         | DMA_RX_EN                                                                                                                                                                |
| 23:22          | /          | /           | /                                                                                                                                                                        |
| 21:16          | R/W        | 0x10        | RX_TRIG<br>When DMA_RX_EN is set, send DMA RX Req when the data byte number in RECV_FIFO reaches RX_TRIG or Read Packet Transmission completed with RECV_FIFO not empty. |
| 15:9           | /          | /           | /                                                                                                                                                                        |
| 8              | R/W        | 0x0         | DMA_TX_EN                                                                                                                                                                |
| 7:6            | /          | /           | /                                                                                                                                                                        |
| 5:0            | R/W        | 0x10        | TX_TRIG<br>When DMA_TX_EN set, send DMA TX Req when there is no less than DMA_TX_TRIG empty byte number in SEND_FIFO.                                                    |

#### 10.1.6.17. 0x021C TWI\_DRV FIFO Content Register(Default Value:0x0000\_0000)

| Offset: 0x021C |            |             | Register Name: TWI_DRV_FIFO_CON                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:23          | /          | /           | /                                                                                                  |
| 22             | R/WAC      | 0x0         | RECV_FIFO_CLEAR<br>Set this bit to clear RECV_FIFO pointer, and this bit is cleared automatically. |
| 21:16          | R          | 0x0         | RECV_FIFO_CONTENT<br>The number of data in RECV_FIFO                                               |

|      |       |     |                                                                                                    |
|------|-------|-----|----------------------------------------------------------------------------------------------------|
| 15:7 | /     | /   | /                                                                                                  |
| 6    | R/WAC | 0x0 | SEND_FIFO_CLEAR<br>Set this bit to clear SEND_FIFO pointer, and this bit is cleared automatically. |
| 5:0  | R     | 0x0 | SEND_FIFO_CONTENT<br>The number of data in SEND_FIFO                                               |

#### 10.1.6.18. 0x0300 TWI\_DRV Send Data FIFO Access Register(Default Value:0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: TWI_DRV_SEND_FIFO_ACC                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:8           | /          | /           | /                                                                                                         |
| 7:0            | W          | 0x0         | SEND_DATA_FIFO<br>Address of a 32x8 SEND_FIFO, which stores reg address and data sending to slave device. |

#### 10.1.6.19. 0x0304 TWI\_DRV Receive Data FIFO Access Register(Default Value:0x0000\_0000)

| Offset: 0x0304 |            |             | Register Name: TWI_DRV_RECV_FIFO_ACC                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:8           | /          | /           | /                                                                                           |
| 7:0            | R          | 0x0         | RECV_DATA_FIFO<br>Address of a 32x8 RECV_FIFO, which stores data received from slave device |

## 10.2. UART

### 10.2.1. Overview

The UART is used for serial communication with a peripheral, modem (data carrier equipment, DCE) or data set. Data is written from a master (CPU) over the APB bus to the UART and it is converted to serial form and transmitted to the destination device. Serial data is also received by the UART and stored for the master (CPU) to read back.

The UART contains registers to control the character length, baud rate, parity generation/checking, and interrupt generation. Although there is only one interrupt output signal from the UART, there are several prioritized interrupt types that can be responsible for its assertion. Each of the interrupt types can be separately enabled/disabled with the control registers.

The UART has 16450 and 16550 modes of operation, which are compatible with a range of standard software drivers. In 16550 mode, transmit and receive operations are both buffered by FIFOs. In 16450 mode, these FIFOs are disabled.

The UART supports word lengths from five to eight bits, an optional parity bit and 1, 1 ½ or 2 stop bits, and is fully programmable by an AMBA APB CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. Eight modem control lines and a diagnostic loop-back mode are provided.

Interrupts can be generated for a range of TX Buffer/FIFO, RX Buffer/FIFO, Modem Status and Line Status conditions.

For integration in system where Infrared SIR serial data format is required, the UART can be configured to have a software-programmable IrDA SIR mode. If this mode is not selected, only the UART (RS232 standard) serial data format is available.

The UART has the following features:

- Compatible with industry-standard 16550 UARTs
- Capable of speed up to 4 Mbit/s with 64 MHz APB clock, and speed up to 1.5 Mbit/s with 24 MHz APB clock
- Supports 5 to 8 data bits and 1/1.5/2 stop bits
- Supports even, odd or no parity
- Supports DMA controller interface
- Supports software/hardware flow control
- Supports IrDA 1.0 SIR
- Supports RS-485/9-bit mode

### 10.2.2. Block Diagram

Figure 10-11 shows a block diagram of the UART.



Figure 10- 11. UART Block Diagram

### 10.2.3. Operations and Functional Descriptions

#### 10.2.3.1. External Signals

Table 10-3 describes the external signals of UART.

Table 10- 3. UART External Signals

| Signal    | Type | Description                |
|-----------|------|----------------------------|
| UART0_TX  | O    | UART0 Data Transmit        |
| UART0_RX  | I    | UART0 Data Receive         |
| UART1_TX  | O    | UART1 Data Transmit        |
| UART1_RX  | I    | UART1 Data Receive         |
| UART1_CTS | I    | UART1 Data Clear to Send   |
| UART1_RTS | O    | UART1 Data Request to Send |
| UART2_TX  | O    | UART2 Data Transmit        |
| UART2_RX  | I    | UART2 Data Receive         |
| UART2_CTS | I    | UART2 Data Clear to Send   |
| UART2_RTS | O    | UART2 Data Request to Send |
| UART3_TX  | O    | UART3 Data Transmit        |
| UART3_RX  | I    | UART3 Data Receive         |
| UART3_CTS | I    | UART3 Data Clear to Send   |
| UART3_RTS | O    | UART3 Data Request to Send |
| UART4_TX  | O    | UART4 Data Transmit        |
| UART4_RX  | I    | UART4 Data Receive         |
| UART4_CTS | I    | UART4 Data Clear to Send   |

|           |   |                            |
|-----------|---|----------------------------|
| UART4_RTS | O | UART4 Data Request to Send |
| S_UART_TX | O | S_UART Data Transmit       |
| S_UART_RX | I | S_UART Data Receive        |

### 10.2.3.2. Clock Sources

Table 10-4 describes the clock sources of UART.

Table 10- 4. UART Clock Sources

| Clock Sources | Description   |
|---------------|---------------|
| APB2_CLK      | Clock of APB2 |

### 10.2.3.3. Typical Application

Figure 10-12 shows the application block diagram of UART.



Figure 10- 12. UART Application Diagram

### 10.2.3.4. UART Timing Diagram



Figure 10- 13. UART Serial Data Format



Figure 10- 14. RTS/CTS Autoflow Control Timing



Figure 10- 15. Serial IrDA Data Format



Figure 10- 16. RS-485 Timing

### 10.2.3.5. UART Operating Mode

#### 10.2.3.5.1. Basic Mode Setting

The **UART\_LCR** register can set basic parameter of a data frame: data width(5 to 8 bits), stop bit number(1/1.5/2), parity type.

A frame transfer of the UART includes the start signal, data signal, parity bit and stop signal. The LSB is transmitted first.

- Start signal(start bit): It is the start flag of a data frame. According to UART protocol, the low level of TXD signal indicates the start of a data frame. When the UART transmits data, the level need hold high.

- Data signal(data bit): The data bit width can be configured as 5-bit,6-bit,7-bit,8-bit through different applications.
- Parity bit: It is 1-bit error correction signal. Parity bit includes odd parity, even parity. The UART can enable and disable the parity bit by setting the **UART\_LCR** register.
- Stop Signal(stop bit): It is the stop bit of a data frame. The stop bit can be set to 1-bit,1.5-bit and 2-bit by the **UART\_LCR** register. The high level of TXD signal indicates the end of a data frame.

#### 10.2.3.5.2. Baud Rate Setting

The baud rate is calculated as follows: Baud rate = SCLK /(16 \* divisor). SCLK is usually APB2 and can be set in CCU. Divisor is frequency divider of UART. The frequency divider has 16-bit, the low 8-bit is in the **UART\_DLL** register, the high 8-bit is in the **UART\_DLH** register.

The relationship between different UART mode and error rate is as follows.

**Table 10- 5. UART Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Over sampling | Error(%) |
|--------------|---------|-----------|---------------|----------|
| 24000000     | 5000    | 300       | 16            | 0        |
| 24000000     | 2500    | 600       | 16            | 0        |
| 24000000     | 1250    | 1200      | 16            | 0        |
| 24000000     | 625     | 2400      | 16            | 0        |
| 24000000     | 313     | 4800      | 16            | -0.16    |
| 24000000     | 156     | 9600      | 16            | 0.16     |
| 24000000     | 78      | 19200     | 16            | 0.16     |
| 24000000     | 39      | 38400     | 16            | 0.16     |
| 24000000     | 26      | 57600     | 16            | 0.16     |
| 24000000     | 13      | 115200    | 16            | 0.16     |
| 48000000     | 13      | 230400    | 16            | 0.16     |
| 64000000     | 7       | 576000    | 16            | -0.794   |
| 75000000     | 5       | 921600    | 16            | 1.725    |
| 48000000     | 3       | 1000000   | 16            | 0        |
| 24000000     | 1       | 1500000   | 16            | 0        |
| 48000000     | 1       | 3000000   | 16            | 0        |
| 64000000     | 1       | 4000000   | 16            | 0        |

**Table 10- 6. IrDA Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Encoding | Error(%) |
|--------------|---------|-----------|----------|----------|
| 24000000     | 5000    | 300       | 3/16     | 0        |
| 24000000     | 2500    | 600       | 3/16     | 0        |
| 24000000     | 1250    | 1200      | 3/16     | 0        |
| 24000000     | 625     | 2400      | 3/16     | 0        |
| 24000000     | 313     | 4800      | 3/16     | -0.16    |
| 24000000     | 156     | 9600      | 3/16     | 0.16     |
| 24000000     | 78      | 19200     | 3/16     | 0.16     |

|          |    |        |      |      |
|----------|----|--------|------|------|
| 24000000 | 39 | 38400  | 3/16 | 0.16 |
| 24000000 | 26 | 57600  | 3/16 | 0.16 |
| 24000000 | 13 | 115200 | 3/16 | 0.16 |

**Table 10- 7. RS485 Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Encoding | Error(%) |
|--------------|---------|-----------|----------|----------|
| 24000000     | 5000    | 300       | 16       | 0        |
| 24000000     | 2500    | 600       | 16       | 0        |
| 24000000     | 1250    | 1200      | 16       | 0        |
| 24000000     | 625     | 2400      | 16       | 0        |
| 24000000     | 313     | 4800      | 16       | -0.16    |
| 24000000     | 156     | 9600      | 16       | 0.16     |
| 24000000     | 78      | 19200     | 16       | 0.16     |
| 24000000     | 39      | 38400     | 16       | 0.16     |
| 24000000     | 26      | 57600     | 16       | 0.16     |
| 24000000     | 13      | 115200    | 16       | 0.16     |

#### 10.2.3.5.3. DLAB Setting

DLAB control bit (**UART\_LCR[7]**) is the access control bit of divisor Latch register.

If DLAB is 0, then 0x00 offset address is **TX/RX FIFO** register, 0x04 offset address is **IER** register.

If DLAB is 1, then 0x00 offset address is **DLL** register, 0x04 offset address is **DLH** register.

When UART initial, divisor need be set. That is, writing 1 to DLAB can access the **DLL** and **DLH** register, after finished setting, writing 0 to DLAB can access the **TX/RX FIFO** register.

#### 10.2.3.5.4. CHCFG\_AT\_BUSY Setting

The function of **CHCFG\_AT\_BUSY(UART\_HALT[1])** and **CHANGE\_UPDATE(UART\_HALT[2])** are as follows.

**CHCFG\_AT\_BUSY**(configure at busy): Enable the bit, software can also set UART controller when UART is busy, such as the LCR,DLH,DLL register.

**CHANGE\_UPDATE**(update configuration): If **CHCFG\_AT\_BUSY** is enabled, and **CHANGE\_UPDATE** is written to 1, the configuration of UART controller can be updated. After completed update, the bit is cleared to 0 automatically.

Setting divisor, performs the following steps:

Step1 Write 1 to **CHCFG\_AT\_BUSY** to enable “configure at busy”.

Step2 Write 1 to **DLAB**, and set **DLH** and **DLL**.

Step3 Write 1 to **CHANGE\_UPDATE** to update configuration. The bit is cleared to 0 automatically after completed update.

#### 10.2.3.5.5. UART Busy

**UART\_USR[0]** is a busy flag of UART controller or not.

When TX transmits data, or RX receives data, or TX FIFO is not empty, or RX FIFO is not empty, then the BUSY flag bit can be set to 1 by hardware, which indicates the UART controller is busy.

### 10.2.4. Programming Guidelines

#### 10.2.4.1. Initialization

##### Step1 System Initialization

- Configure APB2\_CFG\_REG in CCU module to set APB2 bus clock(The clock is 24MHz by default).
- Set UART\_BGR\_REG[UARTx\_GATING] to 1 to enable the module clock, and set UART\_BGR\_REG[UARTx\_RST] to 1 to de-assert the module.

##### Step2 UART Controller Initialization

- IO configuration: Configure GPIO multiplex as UART function, and set UART pins to internal pull-up mode(For detail, see the description in Port Controller).
- Baud-rate configuration:
  - Set UART baud-rate(refer to section 10.2.3.5.2);
  - Write UART\_FCR[FIFOE] to 1 to enable TX/RX FIFO;
  - Write UART\_HALT[HALT\_TX] to 1 to disable TX transfer;
  - Set UART\_LCR[DLAB] to 1, remain default configuration for other bits; set 0x00 offset address to UART\_DLL register, set 0x04 offset address to UART\_DLH register;
  - Write the high 8-bit of divisor to UART\_DLH, and write the low 8-bit of divisor to UART\_DLL;
  - Set UART\_LCR[DLAB] to 0, remain default configuration for other bits; set 0x00 offset address to UART\_RBR/UART\_THR register, set 0x04 offset address to UART\_IER register;
  - Set UART\_HALT[HALT\_TX] to 0 to enable TX transfer.

##### Step3 Controller Parameter Configuration

- Set data width, stop bits and even/odd parity type by writing UART\_LCR register.
- Reset, enable FIFO and set FIFO trigger condition by writing UART\_FCR register.
- Set flow control parameter by writing UART\_MCR register.

##### Step4 Interrupt Configuration

- Configure UART interrupt vector number to request UART interrupt(please refer to GIC module for interrupt vector number).
- In DMA mode, write UART\_IER to 0 to disable interrupt; write UART\_HSK[Handshake configuration] to 0xE5 to set DMA handshake mode; write UART\_FCR[DMAM] to 1 to set DMA transmission/reception mode; set DMA parameter and request DMA interrupt according to DMA configuration process.
- In Interrupt mode, configure UART\_IER to enable corresponding interrupt according to requirements: such as transmit(TX) interrupt, receive(RX) interrupt, receive line status interrupt, RS48 interrupt, etc. (Here TX/RX interrupt is usually used).

#### 10.2.4.2. Data Transfer/Receive in Query Mode

##### Data transfer

**Step1** Write data to UART\_THR to start data transfer.

**Step2** Check TX\_FIFO status by reading UART\_USR[TFNF]. If the bit is 1, data can continue to be written; if the bit is 0, wait data transfer, and data cannot continue to write until FIFO is not full.

##### Data receive

**Step1** Check RX\_FIFO status by reading UART\_USR[RFNE].

**Step2** Read data from UART\_RBR if RX\_FIFO is not empty.

**Step3** If UART\_USR[RFNE] is 0, data is received completely.

#### 10.2.4.3. Data Transfer/Receive in Interrupt Mode

##### Data transfer

**Step1** Set UART\_IER[ETBEI] to 1 to enable UART transfer interrupt.

**Step2** Write data to be transmitted to UART\_THR.

**Step3** When the data of TX\_FIFO meets trigger condition(such as FIFO/2, FIFO/4), UART transfer interrupt is generated.

**Step4** Check UART\_USR[TFE] and determine whether TX\_FIFO is empty. If UART\_USR[TFE] is 1, it indicates that the data in TX\_FIFO is transmitted completely.

**Step5** Clear UART\_IER[ETBEI] to 0 to disable transfer interrupt.

##### Data receive

**Step1** Set UART\_IER[ERBFI] to 1 to enable UART receive interrupt.

**Step2** When the received data from RX\_FIFO meets trigger condition(such as FIFO/2, FIFO/4), UART receive interrupt is generated.

**Step3** Read data from UART\_RBR.

**Step4** Check RX\_FIFO status by reading UART\_USR[RFNE] and determine whether to read data. If the bit is 1, continue to read data from UART\_RBR until UART\_USR[RFNE] is cleared to 0, which indicates data is received completely.

Figure 10-17 shows the process of UART transmitting and receiving data in interrupt mode.



Figure 10- 17. Process of UART Transmitting/Receiving Data in Interrupt Mode

#### 10.2.4.4. Data Transfer/Receive in DMA Mode

##### Data transfer

- Step1** Configure UART DMA interrupt according to initialization process.
- Step2** Configure DMA data channel, including transfer source address, transfer destination address, number of data to be transferred, and transfer type, etc(For details, see the description in DMAC module).
- Step3** Enable DMA transfer function of the UART by setting the register of DMA module.
- Step4** Determine whether UART data is transferred completely based on DMA status. If all data is transferred completely, disable DMA transfer function of the UART.

##### Data receive

- Step1** Configure DMA data channel, including transfer source address, transfer destination address, number of data to be transferred, and transfer type, etc(For details, see the description in DMAC module).
- Step2** Enable DMA receive function of the UART by setting the register of DMA module.
- Step3** Determine whether UART data is received completely based on DMA status. If all data is received completely, disable DMA receive function of the UART.

Figure 10-18 shows the process of UART transmitting data in DMA mode.



**Figure 10- 18. Process of DMA Transmitting Data in DMA Mode**

#### 10.2.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| UART0       | 0x05000000   |
| UART1       | 0x05000400   |
| UART2       | 0x05000800   |

|        |            |
|--------|------------|
| UART3  | 0x05000C00 |
| UART4  | 0x05001000 |
| R_UART | 0x07080000 |

| Register Name | Offset | Description                               |
|---------------|--------|-------------------------------------------|
| UART_RBR      | 0x0000 | UART Receive Buffer Register              |
| UART_THR      | 0x0000 | UART Transmit Holding Register            |
| UART_DLL      | 0x0000 | UART Divisor Latch Low Register           |
| UART_DLH      | 0x0004 | UART Divisor Latch High Register          |
| UART_IER      | 0x0004 | UART Interrupt Enable Register            |
| UART_IIR      | 0x0008 | UART Interrupt Identity Register          |
| UART_FCR      | 0x0008 | UART FIFO Control Register                |
| UART_LCR      | 0x000C | UART Line Control Register                |
| UART_MCR      | 0x0010 | UART Modem Control Register               |
| UART_LSR      | 0x0014 | UART Line Status Register                 |
| UART_MSR      | 0x0018 | UART Modem Status Register                |
| UART_SCH      | 0x001C | UART Scratch Register                     |
| UART_USR      | 0x007C | UART Status Register                      |
| UART_TFL      | 0x0080 | UART Transmit FIFO Level Register         |
| UART_RFL      | 0x0084 | UART Receive FIFO Level Register          |
| UART_HSK      | 0x0088 | UART DMA Handshake Configuration Register |
| UART_HALT     | 0x00A4 | UART Halt TX Register                     |
| UART_DBG_DLL  | 0x00B0 | UART Debug DLL Register                   |
| UART_DBG_DLH  | 0x00B4 | UART Debug DLH Register                   |

## 10.2.6. Register Description

### 10.2.6.1. 0x0000 UART Receiver Buffer Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_RBR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0            | R          | 0x0         | <p>RBR<br/>Receiver Buffer Register<br/>Data byte received on the serial input port (sin) in UART mode, or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line Status Register (LCR) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register can not read before the next data character arrives, then the data already in the FIFO is preserved, but any incoming data are lost and an</p> |

|  |  |  |                       |
|--|--|--|-----------------------|
|  |  |  | overrun error occurs. |
|--|--|--|-----------------------|

#### 10.2.6.2. 0x0000 UART Transmit Holding Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_THR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0            | W          | 0x0         | <p>THR<br/>Transmit Holding Register<br/>Data is transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] = 1) and THRE is set, 16 number of characters data may be written to the THR before the FIFO is full. When the FIFO is full, any write data results in the write data being lost.</p> |

#### 10.2.6.3. 0x0000 UART Divisor Latch Low Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_DLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0            | R/W        | 0x0         | <p>DLL<br/>Divisor Latch Low<br/>Lower 8 bits of a 16 bits, read/write, Divisor Latch Register contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that when the Divisor Latch Registers (DLL and DLH) are set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLL is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 10.2.6.4. 0x0004 UART Divisor Latch High Register(Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_DLH |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0  | R/W | 0x0 | <p>DLH<br/>Divisor Latch High<br/>Upper 8 bits of a 16 bits, read/write, Divisor Latch Register contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that when the Divisor Latch Registers (DLL and DLH) is set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 10.2.6.5. 0x0004 UART Interrupt Enable Register(Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_IER                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                                                                                                               |
| 7              | R/W        | 0x0         | <p>PTIME<br/>Programmable THRE Interrupt Mode Enable<br/>This is used to enable/disable the generation of THRE Interrupt.<br/>0: Disable<br/>1: Enable</p>                                                      |
| 6:5            | /          | /           | /                                                                                                                                                                                                               |
| 4              | R/W        | 0x0         | <p>RS485_INT_EN<br/>RS485 Interrupt Enable<br/>0:Disable<br/>1:Enable</p>                                                                                                                                       |
| 3              | R/W        | 0x0         | <p>EDSSI<br/>Enable Modem Status Interrupt<br/>This is used to enable/disable the generation of Modem Status Interrupt.<br/>This is the fourth highest priority interrupt.<br/>0: Disable<br/>1: Enable</p>     |
| 2              | R/W        | 0x0         | <p>ELSI<br/>Enable Receiver Line Status Interrupt<br/>This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt.<br/>0: Disable<br/>1: Enable</p> |
| 1              | R/W        | 0x0         | ETBEI                                                                                                                                                                                                           |

|   |     |     |                                                                                                                                                                                                                                                                                              |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | Enable Transmit Holding Register Empty Interrupt<br>This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt.<br>0: Disable<br>1: Enable                                                                  |
| 0 | R/W | 0x0 | ERBFI<br>Enable Received Data Available Interrupt<br>This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFOs enabled). These are the second highest priority interrupt.<br>0: Disable<br>1: Enable |

#### 10.2.6.6. 0x0008 UART Interrupt Identity Register(Default Value: 0x0000\_0001)

| Offset: 0x0008 |            |             | Register Name: UART_IIR                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:6            | R          | 0x0         | FEFLAG<br>FIFOs Enable Flag<br>This is used to indicate whether the FIFOs are enabled or disabled.<br>00: Disable<br>11: Enable                                                                                                                                                                                                                                                                                                                                                     |
| 5:4            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3:0            | R          | 0x1         | IID<br>Interrupt ID<br>This indicates the highest priority pending interrupt which can be one of the following types:<br>0000: modem status<br>0001: no interrupt pending<br>0010: THR empty<br>0011: RS485 Interrupt<br>0100: received data available<br>0110: receiver line status<br>0111: busy detect<br>1100: character timeout<br>The bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt. |

| Interrupt ID | Priority Level | Interrupt Type       | Interrupt Source                                 | Interrupt Reset                  |
|--------------|----------------|----------------------|--------------------------------------------------|----------------------------------|
| 0001         | -              | None                 | None                                             | -                                |
| 0110         | Highest        | Receiver line status | Overrun/parity/framing errors or break interrupt | Reading the line status register |

|      |         |                                 |                                                                                                                                                                                            |                                                                                                                                                                                                |
|------|---------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0011 | Second  | RS485 Interrupt                 | In RS485 mode, receives address data and match setting address                                                                                                                             | Writes 1 to addr flag to reset                                                                                                                                                                 |
| 0100 | Third   | Received data available         | Receiver data available (non-FIFO mode or FIFOs disabled) or RCVR FIFO trigger level reached (FIFO mode and FIFOs enabled)                                                                 | Reading the receiver buffer register (non-FIFO mode or FIFOs disabled) or the FIFO drops below the trigger level (FIFO mode and FIFOs enabled)                                                 |
| 1100 | Fourth  | Character timeout indication    | No characters in or out of the RCVR FIFO during the last 4 character times and there is at least 1character in it during This time                                                         | Reading the receiver buffer register                                                                                                                                                           |
| 0010 | Fifth   | Transmit holding register empty | Transmitter holding register empty (Program THRE mode disabled) or XMIT FIFO at or below threshold (Program THRE mode enabled)                                                             | Reading the IIR register (if source of interrupt); or, writing into THR (FIFOs or THRE mode not selected or disabled) or XMIT FIFO above threshold (FIFOs and THRE mode selected and enabled). |
| 0000 | Sixth   | Modem status                    | Clear to send or data set ready or ring indicator or data carrier detect. Note that if auto flow control mode is enabled, a change in CTS (that is, DCTS set) does not cause an interrupt. | Reading the Modem status register                                                                                                                                                              |
| 0111 | Seventh | Busy detect indication          | UART_16550_COMPATIBLE = NO and master has tried to write to the Line Control Register while the UART is busy (USR[0] is set to one).                                                       | Reading the UART status register                                                                                                                                                               |

#### 10.2.6.7. 0x0008 UART FIFO Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:6            | W          | 0x0         | <p>RT<br/>RCVR Trigger</p> <p>This is used to select the trigger level in the receiver FIFO when the Received Data Available Interrupt is generated. In auto flow control mode it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation.</p> <p>00: 1 character in the FIFO<br/>01: FIFO ¼ full<br/>10: FIFO ½ full<br/>11: FIFO-2 less than full</p> |
| 5:4            | W          | 0x0         | TFT                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

|   |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | <p><b>TX Empty Trigger</b><br/> This is used to select the empty threshold level when the THRE Interrupts are generated and the mode is active. It also determines when the <code>dma_tx_req_n</code> signal is asserted in certain modes of operation.</p> <p>00: FIFO empty<br/> 01: 2 characters in the FIFO<br/> 10: FIFO ¼ full<br/> 11: FIFO ½ full</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3 | W | 0x0 | <p><b>DMAM</b><br/> <b>DMA Mode</b><br/> 0: Mode 0<br/> In this mode, if PTE is high and TX FIFO is enabled, the TX DMA request will send when TFL is less than or equal to FIFO Trigger Level. If PTE is high and TX FIFO is disabled, the TX DMA request will send when THRE is empty. If PTE is low, the TX DMA request will send when the TX FIFO is empty.<br/> If <code>dma_pte_rx</code> is high and RX FIFO is enabled, the rx drq will send when RFL is equal to or more than FIFO Trigger Level.</p> <p>1: Mode 1<br/> In this mode, if TX FIFO is enabled and the PTE is high, the TX DMA request will send when TFL is less than or equal to FIFO Trigger Level. If PTE is low, the TX DMA request will send when TX FIFO is empty and the request stops only when TX FIFO is full.<br/> If RFL is equal to or more than FIFO Trigger Level, the rx drq will be set to 1, in otherwise, it will be set to 0.</p> |
| 2 | W | 0x0 | <p><b>XFIFOR</b><br/> <b>XMIT FIFO Reset</b><br/> The bit resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request.<br/> It is 'self-clearing'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1 | W | 0x0 | <p><b>RFIFOR</b><br/> <b>RCVR FIFO Reset</b><br/> The bit resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request.<br/> It is 'self-clearing'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0 | W | 0x0 | <p><b>FIFOE</b><br/> <b>Enable FIFOs</b><br/> The bit enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. Whenever the value of this bit is changed, both the XMIT and RCVR controller portion of FIFOs is reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 10.2.6.8. 0x000C UART Line Control Register(Default Value: 0x0000\_0000)

|                       |                                |
|-----------------------|--------------------------------|
| <b>Offset: 0x000C</b> | <b>Register Name: UART_LCR</b> |
|-----------------------|--------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7    | R/W        | 0x0         | <p>DLAB<br/>Divisor Latch Access Bit<br/>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial baud rate setup in order to access other registers.<br/>0: Select RX Buffer Register (RBR) / TX Holding Register(THR) and Interrupt Enable Register (IER)<br/>1: Select Divisor Latch LS Register (DLL) and Divisor Latch MS Register (DLM)</p>                                                                               |
| 6    | R/W        | 0x0         | <p>BC<br/>Break Control Bit<br/>This is used to cause a break condition to be transmitted to the receiving device. If setting to 0, the serial output is forced to the spacing (logic 0) state. When not in Loopback mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE is enabled and active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low.</p>                                                                             |
| 5:4  | R/W        | 0x0         | <p>EPS<br/>Even Parity Select<br/>It is writeable only when UART is not busy (USR[0] is zero) and always writable/readable. This is used to select between even and odd parity, when parity is enabled (PEN set to one). Setting the LCR[5] is unset to reverse the LCR[4].<br/>00: Odd Parity<br/>01: Even Parity<br/>1X: Reverse LCR[4]<br/>In RS485 mode, it is the 9<sup>th</sup> bit--address bit.<br/>11:9<sup>th</sup> bit = 0, indicates that this is a data byte.<br/>10:9<sup>th</sup> bit = 1, indicates that this is an address byte.<br/><b>Note: When using this function, PEN(LCR[3]) must set to 1.</b></p> |
| 3    | R/W        | 0x0         | <p>PEN<br/>Parity Enable<br/>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.<br/>0: Parity disabled<br/>1: Parity enabled</p>                                                                                                                                                                                                                                                                                                                            |
| 2    | R/W        | 0x0         | <p>STOP<br/>Number of stop bits<br/>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If setting to 0, one stop bit is</p>                                                                                                                                                                                                                                                                                                                                                          |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | <p>transmitted in the serial data. If setting to 1 and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.</p> <p>0: 1 stop bit<br/>1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit</p> |
| 1:0 | R/W | 0x0 | <p>DLS<br/>Data Length Select<br/>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of data bits per character that the peripheral transmits and receives. The number of bit that may be selected areas follows:</p> <p>00: 5 bits<br/>01: 6 bits<br/>10: 7 bits<br/>11: 8 bits</p>                                          |

#### 10.2.6.9. 0x0010 UART Modem Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:6            | R/W        | 0x0         | <p>UART_FUNCTION<br/>Select IrDA or RS485<br/>00: UART Mode<br/>01: IrDA SIR Mode<br/>10: RS485 Mode<br/>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5              | R/W        | 0x0         | <p>AFCE<br/>Auto Flow Control Enable<br/>When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled.<br/>0: Auto Flow Control mode disabled<br/>1: Auto Flow Control mode enabled</p>                                                                                                                                                                                                                                                                                                       |
| 4              | R/W        | 0x0         | <p>LOOP<br/>Loop Back Mode<br/>0: Normal Mode<br/>1: Loop Back Mode<br/>This is used to put the UART into a diagnostic mode for test purposes. If operating in UART mode (SIR_MODE != Enabled or not active, MCR[6] is set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n,</p> |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | out1_n, out2_n) are looped back to the inputs, internally. If operating in infrared mode (SIR_MODE == Enabled AND active, MCR[6] is set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:2 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1   | R/W | 0x0 | <p><b>RTS</b><br/>Request to Send</p> <p>This is used to directly control the Request to Send (rts_n) output. The RTS (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] is set to zero), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] is set to one) and FIFOs enable (FCR[0] is set to one), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when MCR[1] is set low.</p> <p>0: rts_n de-asserted (logic 1)<br/>1: rts_n asserted (logic 0)</p> <p>Note that in Loopback mode (MCR[4] is set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input.</p> |
| 0   | R/W | 0x0 | <p><b>DTR</b><br/>Data Terminal Ready</p> <p>This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n.</p> <p>0: dtr_n de-asserted (logic 1)<br/>1: dtr_n asserted (logic 0)</p> <p>The Data Terminal Ready output is used to inform the modem or data set that the UART is ready to establish communications.</p> <p>Note that in Loopback mode (MCR[4] is set to one), the dtr_n output is held inactive high while the value of this location is internally looped back to an input.</p>                                                                                                                                                                                                                                                                                                                                                                         |

#### 10.2.6.10. 0x0014 UART Line Status Register(Default Value: 0x0000\_0060)

| Offset:0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                           |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                       |
| 31:8          | /          | /           | /                                                                                                                                                                                                                                                                                                                 |
| 7             | R          | 0x0         | <p><b>FIFOERR</b><br/>RX Data Error in FIFO</p> <p>When FIFOs are disabled, this bit is always 0. When FIFOs are enabled, this bit is set to "1" when there is at least one PE, FE, or BI in the RX FIFO. It is cleared by a read from the LSR register provided, there are no subsequent errors in the FIFO.</p> |

|   |    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | R  | 0x1 | <p><b>TEMT</b><br/>Transmitter Empty<br/>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register and the TX Shift Register are empty. If the FIFOs are enabled, this bit is set whenever the TX FIFO and the TX Shift Register are empty. In both cases, this bit is cleared when a byte is written to the TX data channel.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5 | R  | 0x1 | <p><b>THRE</b><br/>TX Holding Register Empty<br/>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register is empty and ready to accept new data and it is cleared when the CPU writes to the TX Holding Register.</p> <p>If the FIFOs are enabled, this bit is set to "1" whenever the TX FIFO is empty and it is cleared when at least one byte is written to the TX FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4 | R  | 0x0 | <p><b>BI</b><br/>Break Interrupt<br/>This is used to indicate the detection of a break sequence on the serial input data.<br/>If in UART mode (<code>SIR_MODE == Disabled</code>), it is set whenever the serial input, <code>sir_in</code>, is held in a logic '0' state for longer than the sum of <i>start time + data bits + parity + stop bits</i>.<br/><br/>If in infrared mode (<code>SIR_MODE == Enabled</code>), it is set whenever the serial input, <code>sir_in</code>, is continuously pulsed to logic '0' for longer than the sum of <i>start time + data bits + parity + stop bits</i>. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART.<br/><br/>In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO. Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.</p> |
| 3 | RC | 0x0 | <p><b>FE</b><br/>Framing Error<br/>This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.<br/><br/>In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p>                                                                                                                                                                                                                                                |

|   |    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---|----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |    |     | 0: no framing error<br>1:framing error<br>Reading the LSR clears the FE bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2 | RC | 0x0 | PE<br>Parity Error<br>This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).<br>0: no parity error<br>1: parity error<br>Reading the LSR clears the PE bit.                               |
| 1 | RC | 0x0 | OE<br>Overrun Error<br>This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.<br>0: no overrun error<br>1: overrun error<br>Reading the LSR clears the OE bit. |
| 0 | R  | 0x0 | DR<br>Data Ready<br>This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.<br>0: no data ready<br>1: data ready<br>This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.                                                                                                                                                                                                                                                                                                           |

#### 10.2.6.11. 0x0018 UART Modem Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                                                                                               |
| 7              | R          | 0x0         | DCD<br>Line State of Data Carrier Detect<br>This is used to indicate the current state of the modem control line dcd_n. This bit is the complement of dcd_n. When the Data Carrier Detect input |

|   |    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |    |     | (dcd_n) is asserted it is an indication that the carrier has been detected by the modem or data set.<br>0: dcd_n input is de-asserted (logic 1)<br>1: dcd_n input is asserted (logic 0)                                                                                                                                                                                                                                                                                                                       |
| 6 | R  | 0x0 | RI<br>Line State of Ring Indicator<br>This is used to indicate the current state of the modem control line ri_n. This bit is the complement of ri_n. When the Ring Indicator input (ri_n) is asserted it is an indication that a telephone ringing signal has been received by the modem or data set.<br>0: ri_n input is de-asserted (logic 1)<br>1: ri_n input is asserted (logic 0)                                                                                                                        |
| 5 | R  | 0x0 | DSR<br>Line State of Data Set Ready<br>This is used to indicate the current state of the modem control line dsr_n. This bit is the complement of dsr_n. When the Data Set Ready input (dsr_n) is asserted it is an indication that the modem or data set is ready to establish communications with UART.<br>0: dsr_n input is de-asserted (logic 1)<br>1: dsr_n input is asserted (logic 0)<br>In Loopback Mode (MCR[4] is set to 1), DSR is the same as MCR[0] (DTR).                                        |
| 4 | R  | 0x0 | CTS<br>Line State of Clear To Send<br>This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted it is an indication that the modem or data set is ready to exchange data with UART.<br>0: cts_n input is de-asserted (logic 1)<br>1: cts_n input is asserted (logic 0)<br>In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS).                                                             |
| 3 | RC | 0x0 | DDCD<br>Delta Data Carrier Detect<br>This is used to indicate that the modem control line dcd_n has changed since the last time the MSR was read.<br>0: no change on dcd_n since last read of MSR<br>1: change on dcd_n since last read of MSR<br>Reading the MSR clears the DDCD bit.<br><b>Note: If the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.</b> |
| 2 | RC | 0x0 | TERI<br>Trailing Edge Ring Indicator<br>This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR was read.<br>0: no change on ri_n since last read of MSR                                                                                                                                                                                                                                                             |

|   |    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |    |     | 1: change on ri_n since last read of MSR<br>Reading the MSR clears the TERI bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1 | RC | 0x0 | <p>DDSR<br/>Delta Data Set Ready<br/>This is used to indicate that the modem control line dsr_n has changed since the last time the MSR was read.</p> <p>0: no change on dsr_n since last read of MSR<br/>1: change on dsr_n since last read of MSR<br/>Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4] = 1), DDSR reflects changes on MCR[0] (DTR).</p> <p><b>Note: If the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</b></p>      |
| 0 | RC | 0x0 | <p>DCTS<br/>Delta Clear to Send<br/>This is used to indicate that the modem control line cts_n has changed since the last time the MSR was read.</p> <p>0: no change on ctsdsr_n since last read of MSR<br/>1: change on ctsdsr_n since last read of MSR<br/>Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS).</p> <p><b>Note: If the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</b></p> |

#### 10.2.6.12. 0x001C UART Scratch Register(Default Value: 0x0000\_0000)

| Offset: 0x001C |            | Register Name: UART_SCH |                                                                                                                                                          |
|----------------|------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex             | Description                                                                                                                                              |
| 31:8           | /          | /                       | /                                                                                                                                                        |
| 7:0            | R/W        | 0x0                     | <p>SCRATCH_REG<br/>Scratch Register<br/>This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART.</p> |

#### 10.2.6.13. 0x007C UART Status Register(Default Value: 0x0000\_0006)

| Offset: 0x007C |            |             | Register Name: UART_USR                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:5           | /          | /           | /                                                                                                       |
| 4              | R          | 0x0         | <p>RFF<br/>Receive FIFO Full<br/>This is used to indicate that the receive FIFO is completely full.</p> |

|   |   |     |                                                                                                                                                                                                                                          |
|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | 0: Receive FIFO not full<br>1: Receive FIFO Full<br><br>This bit is cleared when the RX FIFO is no longer full.                                                                                                                          |
| 3 | R | 0x0 | RFNE<br><br>Receive FIFO Not Empty<br><br>This is used to indicate that the receive FIFO contains one or more entries.<br>0: Receive FIFO is empty<br>1: Receive FIFO is not empty<br><br>This bit is cleared when the RX FIFO is empty. |
| 2 | R | 0x1 | TFE<br><br>Transmit FIFO Empty<br><br>This is used to indicate that the transmit FIFO is completely empty.<br>0: Transmit FIFO is not empty<br>1: Transmit FIFO is empty<br><br>This bit is cleared when the TX FIFO is no longer empty. |
| 1 | R | 0x1 | TFNF<br><br>Transmit FIFO Not Full<br><br>This is used to indicate that the transmit FIFO is not full.<br>0: Transmit FIFO is full<br>1: Transmit FIFO is not full<br><br>This bit is cleared when the TX FIFO is full.                  |
| 0 | R | 0x0 | BUSY<br><br>UART Busy Bit<br>0: Idle or inactive<br>1: Busy                                                                                                                                                                              |

#### 10.2.6.14. 0x0080 UART Transmit FIFO Level Register(Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: UART_TFL                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:9           | /          | /           | /                                                                                                        |
| 8:0            | R          | 0x0         | TFL<br><br>Transmit FIFO Level<br><br>The bit indicates the number of data entries in the transmit FIFO. |

#### 10.2.6.15. 0x0084 UART Receive FIFO Level Register(Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: UART_RFL                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:9           | /          | /           | /                                                                                                      |
| 8:0            | R          | 0x0         | RFL<br><br>Receive FIFO Level<br><br>The bit indicates the number of data entries in the receive FIFO. |

#### 10.2.6.16. 0x0088 UART DMA Handshake Configuration Register(Default Value: 0x0000\_00A5)

| Offset: 0x0088 |            |             | Register Name: UART_HSK                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:8           | /          | /           | /                                                                                |
| 7:0            | R/W        | 0xA5        | Handshake configuration<br>0xA5: DMA wait cycle mode<br>0xE5: DMA handshake mode |

#### 10.2.6.17. 0x00A4 UART Halt TX Register(Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: UART_HALT                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7              | R/W        | 0x0         | PTE<br>The sending of TX_REQ.<br>In DMA1 mode (FIFO on), if PTE is set to 1, when TFL is less than trig, send the DMA request. If PTE is set to 0, when FIFO is empty, send the DMA request. The DMA request will stop when FIFO is full.<br><br>In DMA0 mode, if PTE is set to 1 and FIFO is on, when TFL is less than trig, send DMA request. If PTE is set to 1 and FIFO is off, when THRE is empty, send DMA request. If PTE is set to 0, when FIFO is empty, send DMA request. |
| 6              | R/W        | 0x0         | DMA_PTE_RX<br>The sending of RX_DRQ.<br>In DMA1 mode, when RFL is more than or equal to trig or receive timeout, send DRQ.<br><br>In DMA0 mode, if DMA_PTE_RX is 1 and FIFO is on, when RFL is more than trig, send DRQ. In other cases, once the receive data is valid, send DRQ.                                                                                                                                                                                                  |
| 5              | R/W        | 0x0         | SIR_RX_INVERT<br>SIR Receiver Pulse Polarity Invert<br>0: Not invert receiver signal<br>1: Invert receiver signal                                                                                                                                                                                                                                                                                                                                                                   |
| 4              | R/W        | 0x0         | SIR_TX_INVERT<br>SIR Transmit Pulse Polarity Invert<br>0: Not invert transmit pulse<br>1: Invert transmit pulse                                                                                                                                                                                                                                                                                                                                                                     |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2              | R/WAC      | 0x0         | CHANGE_UPDATE<br>After the user uses HALT[1] to change the baud rate or LCR configuration,                                                                                                                                                                                                                                                                                                                                                                                          |

|   |     |     |                                                                                                                                                                                                                                                                                                               |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | write 1 to update the configuration and wait this bit to self-clear to 0 to finish update process. Writing 0 to this bit has no effect.<br>1: Update trigger, Self clear to 0 when finish update.                                                                                                             |
| 1 | R/W | 0x0 | CHCFG_AT_BUSY<br>This is an enable bit for the user to change LCR register configuration and baud rate register (DLH and DLL) when the UART is busy.<br>1: Enable change when busy                                                                                                                            |
| 0 | R/W | 0x0 | HALT_TX<br>Halt TX<br>This register is used to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.<br>0 : Halt TX disabled<br>1 : Halt TX enabled<br><b>Note: If FIFOs are not enabled, the setting has no effect on operation.</b> |

#### 10.2.6.18. 0x00B0 UART DBG DLL Register(Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: UART_DBG_DLL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R/W        | 0x0         | DEBUG DLL                   |

#### 10.2.6.19. 0x00B4 UART DBG DLH Register(Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: UART_DBG_DLH |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R/W        | 0x0         | DEBUG DLH                   |

## 10.3. SPI

### 10.3.1. Overview

The SPI is a full-duplex, synchronous, serial communication interface which allows rapid data communication with fewer software interrupts. The SPI controller contains one 64x8 bits receiver buffer (RXFIFO) and one 64x8 bits transmit buffer (TXFIFO). It can work at master mode and slave mode.

The SPI has the following features:

- Full-duplex synchronous serial interface
- Master/slave configurable
- 8-bit wide by 64-entry FIFO for both transmit and receive data
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable
- Interrupt or DMA support
- Supports mode0, mode1, mode2 and mode3
- Supports 3-wire/4-wire SPI
- Supports programmable serial data frame length: 1 bit to 32 bits
- Supports the SPI NAND flash and SPI NOR flash
- Supports standard SPI, dual-output/dual-input SPI, dual I/O SPI, quad-output/quad-input SPI

### 10.3.2. Block Diagram

Figure 10-19 shows a block diagram of the SPI.



Figure 10- 19. SPI Block Diagram

The SPI comprises with:

spi\_rf: Responsible for implementing the internal register, interrupt and DMA Request.

spi\_tbuf: The data length transmitted from AHB to txfifo is converted into 8 bits, then the data is written into the rxfifo.

spi\_rbuf: The block is used to convert the rxfifo data into read data length of AHB.

txfifo, rxfifo: For transmit and receive transfers, data transmitted from the SPI to the external serial device is written into the txfifo; data received from the external serial device into SPI is pushed into the rxfifo.

spi\_cmu: Responsible for implementing SPI bus clock, chip select, internal sample and the generation of transfer clock.

spi\_tx: Responsible for implementing SPI data transfer, the interface of the internal txfifo and status register.

spi\_rx: Responsible for implementing SPI data receive, the interface of the internal rxfifo and status register.

### 10.3.3. Operations and Functional Descriptions

#### 10.3.3.1. External Signals

Table 10-8 describes the external signals of SPI. MOSI and MISO are bidirectional I/O, when SPI is configured as master device, CLK and CS is output pin; when SPI is configurable as slave device, CLK and CS is input pin. The unused SPI ports are used as General Purpose I/O ports.

**Table 10- 8. SPI External Signals**

| Signal    | Description                                                                                                                                                                                                                                                                  | Type |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| SPI0_CS0  | SPI0 Chip Select Signal0, Low Active                                                                                                                                                                                                                                         | I/O  |
| SPI0_CS1  | SPI0 Chip Select Signal1, Low Active                                                                                                                                                                                                                                         | I/O  |
| SPI0_CLK  | SPI0 Clock Signal                                                                                                                                                                                                                                                            | I/O  |
| SPI0_MOSI | SPI0 Master Data Out, Slave Data In                                                                                                                                                                                                                                          | I/O  |
| SPI0_MISO | SPI0 Master Data In, Slave Data Out                                                                                                                                                                                                                                          | I/O  |
| SPI0_WP   | Write protection and active low or Serial Data Input and Output for Quad Input or Quad Output                                                                                                                                                                                | I/O  |
| SPI0_HOLD | The HOLD pin is used to temporarily pause serial communication without deselecting or resetting the device. While the HOLD pin is asserted, transitions on the SCK pin and data on the SI pin will be ignored, or Serial Data Input and Output for Quad Input or Quad Output | I/O  |
| SPI1_CS   | SPI1 Chip Select Signal, Low Active                                                                                                                                                                                                                                          | I/O  |
| SPI1_CLK  | SPI1 Clock Signal                                                                                                                                                                                                                                                            | I/O  |
| SPI1_MOSI | SPI1 Master Data Out, Slave Data In                                                                                                                                                                                                                                          | I/O  |
| SPI1_MISO | SPI1 Master Data In, Slave Data Out                                                                                                                                                                                                                                          | I/O  |
| SPI2_CS   | SPI2 Chip Select Signal, Low Active                                                                                                                                                                                                                                          | I/O  |
| SPI2_CLK  | SPI2 Clock Signal                                                                                                                                                                                                                                                            | I/O  |
| SPI2_MOSI | SPI2 Master Data Out, Slave Data In                                                                                                                                                                                                                                          | I/O  |
| SPI2_MISO | SPI2 Master Data In, Slave Data Out                                                                                                                                                                                                                                          | I/O  |

### 10.3.3.2. Clock Sources

Each SPI interface has 5 different clock sources, users can select one of them to make SPI clock source. Table 10-9 describes the clock sources for SPI.

**Table 10- 9. SPI Clock Sources**

| Clock Sources | Description                                 |
|---------------|---------------------------------------------|
| OSC24M        | 24 MHz Crystal                              |
| PLL_PERIO(1X) | Peripheral Clock, default value is 600 MHz  |
| PLL_PERI1(1X) | Peripheral Clock, default value is 600 MHz  |
| PLL_PERIO(2X) | Peripheral Clock, default value is 1200 MHz |
| PLL_PERI1(2X) | Peripheral Clock, default value is 1200 MHz |

### 10.3.3.3. Typical Application

Figure 10-20 shows the application block diagram when the SPI master device is connected to a slave device.



**Figure 10- 20. SPI Application Block Diagram**

### 10.3.3.4. SPI Transmit Format

The SPI supports 4 different formats for data transfer. Software can select one of the four modes in which the SPI works by setting the bit1(Polarity) and bit0(Phase) of **SPI Transfer Control Register**. The SPI controller master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

During Phase 0, Polarity 0 and Phase 1, Polarity 1 operations, output data changes on the falling clock edge and input data is shifted in on the rising edge.

During Phase 1, Polarity 0 and Phase 0, Polarity 1 operations, output data changes on the rising edges of the clock and is shifted in on falling edges.

The POL defines the signal polarity when SPI\_SCLK is in idle state. The SPI\_SCLK is high level when POL is '1' and it is low level when POL is '0'. The PHA decides whether the leading edge of SPI\_SCLK is used for setup or sample data. The leading edge is used for setup data when PHA is '1' and for sample data when PHA is '0'. The four modes are listed in Table 10-10.

**Table 10- 10. SPI Transmit Format**

| SPI Mode | POL | PHA | Leading Edge    | Trailing Edge   |
|----------|-----|-----|-----------------|-----------------|
| 0        | 0   | 0   | Rising, Sample  | Falling, Setup  |
| 1        | 0   | 1   | Rising, Setup   | Falling, Sample |
| 2        | 1   | 0   | Falling, Sample | Rising, Setup   |
| 3        | 1   | 1   | Falling, Setup  | Rising, Sample  |

Figure 10-21 and Figure 10-22 describe four waveforms for SPI\_SCLK.



**Figure 10- 21. SPI Phase 0 Timing Diagram**



**Figure 10- 22. SPI Phase 1 Timing Diagram**

### 10.3.3.5. SPI Master and Slave Mode

The SPI controller can be configured to a master or slave device. Master mode is selected by setting the **MODE** bit in the **SPI Global Control Register**; slave mode is selected by clearing the **MODE** bit in the **SPI Global Control Register**.

In master mode, SPI\_CLK is generated and transmitted to external device, and data from the TX FIFO is transmitted on the MOSI pin, the data from slave is received on the MISO pin and sent to RX FIFO. Chip Select(SPI\_SS) is active low signal. SPI\_SS must be set low before data are transmitted or received. SPI\_SS can be selected SPI auto control or software manual control. When using auto control, **SS\_OWNER**(the bit 6 in the **SPI Transfer Control Register**) must be cleared(default value is 0);when using manual control, **SS\_OWNER** must be set, Chip Select level is controlled by **SS\_LEVEL** bit(the bit 7 in the **SPI Transfer Control Register**).

In slave mode, after software selects the **MODE** bit to '0', it waits for master initiate a transaction. When the master asserts SPI\_SS and SPI\_CLK is transmitted to the slave, the slave data is transmitted from TX FIFO on MISO pin and data from MOSI pin is received in RX FIFO.

### 10.3.3.6. SPI 3-Wire Mode

The SPI 3-wire mode is only valid when the SPI controller work in master mode, and is selected when the **Work Mode Select(bit[1:0])** is equal to 0x2 in the **SPI Bit-Aligned Transfer Configure Register**. And in the 3-wire mode, the input data and the output data use the same single data line. The following figure describes this mode.



Figure 10- 23. SPI 3-Wire Mode

### 10.3.3.7. SPI Dual-Input/Dual-Output and Dual I/O Mode

The dual read mode(SPI x2) is selected when the **DRM**(bit28) is set in the **SPI Master Burst Control Counter Register**. Using the dual mode allows data to be transferred to or from the device at double the rate of standard single mode SPI devices, data can be read at fast speed using two data bits(MOSI and MISO) at a time. The following figure describes the dual-input/dual-output SPI(Figure 10-24) and the dual I/O SPI(Figure 10-25).



**Figure 10- 24. SPI Dual-Input/Dual-Output Mode**

In the dual-input/dual-output SPI, the command, address, and the dummy bytes output in unit of a single bit in serial mode through SPI\_MOSI line, only the data bytes are output(write) and input(read) in unit of dual bits through the SPI\_MOSI and SPI\_MISO.



**Figure 10- 25. SPI Dual I/O Mode**

In the dual I/O SPI, only the command bytes are output in unit of a single bit in serial mode through SPI\_MOSI line. The address bytes and the dummy bytes are output in unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes are output(write) and input(read) in unit of dual bits through the SPI\_MOSI and SPI\_MISO.

#### 10.3.3.8. SPI Quad-Input/Quad-Output Mode

The quad read mode(SPI x4) is selected when the **Quad\_EN**(bit29) is set in the **SPI Master Burst Control Counter Register**. Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode SPI devices, data can be read at fast speed using four data bits(MOSI, MISO, IO2(WP#)and IO3(HOLD#)) at the same time. The following figure describes the quad-input/quad-output SPI.



Figure 10- 26. SPI Quad-Input/Quad-Output Mode

In the quad-input/quad-output SPI, the command, address, and the dummy bytes are output in unit of a single bit in serial mode through SPI\_MOSI line. Only the data bytes are output(write) and input(read) in unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP# and SPI\_HOLD#.

#### 10.3.3.9. Transmit/Receive Burst in Master Mode

In SPI master mode, the transmit and receive burst(byte in unit) are configured before the SPI transfers serial data between the processor and external device. The transmit bursts are written in MWTC(bit[23:0]) of **SPI Master Transmit Counter Register**. The transmit bursts in single mode before automatically sending dummy burst are written in STC(bit[23:0]) of **SPI Master Burst Control Counter Register**. For dummy data, SPI controller can automatically sent before receiving by writing DBC(bit[27:24]) in **SPI Master Burst Control Counter Register**. If users donot use SPI controller to sent dummy data automatically, then the dummy bursts are used as the transmit counters to write together in MWTC(bit[23:0]) of **SPI Master Transmit Counter Register**. In master mode, the total burst numbers are written in MBC(bit[23:0]) of **SPI Master Burst Counter Register**. When all transmit burst and receive burst are transferred, SPI controller will send an completed interrupt, at the same time, SPI controller will clear DBC,MWTC and MBC.

#### 10.3.3.10. SPI Sample Mode and Run Clock Configuration

The SPI controller runs at 3 kHz~100 MHz at its interface to external SPI devices. The internal SPI clock should run at the same frequency as the outgoing clock in master mode. The SPI clock is selected different clock sources, SPI must configure different work mode. There are three work modes: normal sample mode, delay half cycle sample mode, delay one cycle sample mode. Delay half cycle sample mode is the default mode of SPI controller. The different configuration of SPI sample mode shows in Table 10-11.

**Table 10- 11. SPI Old Sample Mode**

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | Run Clock |
|-------------------------|------------|------------|-----------|
| normal sample           | 1          | 0          | <=24 MHz  |
| delay half cycle sample | 0          | 0          | <=40 MHz  |
| delay one cycle sample  | 0          | 1          | >=60 MHz  |

**Table 10- 12. SPI New Sample Mode**

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | SDC1(bit15) |
|-------------------------|------------|------------|-------------|
| normal sample           | 1          | 0          | 0           |
| delay half cycle sample | 0          | 0          | 0           |
| delay one cycle sample  | 0          | 1          | 0           |
| delay 1.5 cycle sample  | 1          | 1          | 0           |
| delay 2 cycle sample    | 1          | 0          | 1           |
| delay 2.5 cycle sample  | 0          | 0          | 1           |
| delay 3 cycle sample    | 0          | 1          | 1           |

### 10.3.3.11. Calibrate Delay Chain

There is one delay chain in SPI controller, which is used to generate delay to make proper timing between internal SPI clock signal and data signals. Delay chain is made up with 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

The steps to calibrate delay chain are as follows:

**Step1:** Enable SPI. In order to calibrate delay chain by operation registers in SPI, SPI must be enabled through AHB reset and AHB clock gating control registers.

**Step2:** Configure a proper clock for SPI. Calibration delay chain is based on the clock for SPI from CCU module.

**Step3:** Set proper initial delay value. Write 0xA0 to delay control register to set initial delay value 0x20 to delay chain. Then write 0x0 to delay control register to clear this value.

**Step4:** Write 0x8000 to delay control register to start calibrate delay chain.

**Step5:** Wait until the flag(Bit14 in delay control register ) of calibration done is set. The number of delay cells is shown at Bit8~Bit14 in delay control register. The delay time generated by these delay cells is equal to the clock cycle of SPI nearly. This value is the result of calibration.

**Step6:** Calculate the delay time of one delay cell according to the clock cycle of SPI and the result of calibration.

### 10.3.3.12. SPI Error Conditions

If any error conditions occur, hardware will set the corresponding status bits in the **SPI Interrupt Status Register** and stop the transfer. For the SPI controller, the following error scenarios can happen.

#### (1) TX\_FIFO Underrun

TX\_FIFO underrun happens when the CPU/DMA reads from TX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_UDF bit in the **SPI Interrupt Status Register**. The SPI controller will generate an interrupt if interrupts are enabled. Software has to clear the error bit and the TF\_UDF bit. To start a new transaction, software has to reset the FIFO by writing to the SRST(soft reset) bit in the **SPI Global Controller Register**.

#### (2) TX\_FIFO Overflow

TX\_FIFO overflow happens when the CPU/DMA writes into the TX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_OVF bit in the **SPI Interrupt Status Register**. The SPI controller will generate an interrupt if interrupts are enabled. Software has to clear the error bit and the TF\_OVF bit. To start a new transaction, software has to reset the FIFO by writing to the SRST(soft reset) bit in the **SPI Global Controller Register**.

#### (3) RX\_FIFO Underrun

RX\_FIFO underrun happens when the CPU/DMA reads from RX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_UDF bit in the **SPI Interrupt Status Register**. The SPI controller will generate an interrupt if interrupts are enabled. Software has to clear the error bit and the RF\_UDF bit. To start a new transaction, software has to reset the FIFO by writing to the SRST(soft reset) bit in the **SPI Global Controller Register**.

#### (4) RX\_FIFO Overflow

RX\_FIFO overflow happens when the CPU/DMA writes into the RX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_OVF bit in the **SPI Interrupt Status Register**. The SPI controller will generate an interrupt if interrupts are enabled. Software has to clear the error bit and the RF\_OVF bit. To start a new transaction, software has to reset the FIFO by writing to the SRST(soft reset) bit in the **SPI Global Controller Register**.

### 10.3.4. Programming Guidelines

#### 10.3.4.1. CPU or DMA Operation

The SPI transfers serial data between the processor and external device. CPU and DMA are the two main operational modes for SPI. For each SPI, data is simultaneously transmitted(shifted out serially) and received (shifted in serially).SPI has 2 channels, TX channel and RX channel. TX channel has the path from TX FIFO to external device. RX channel has the path from external device to RX FIFO.

**Write Data:** CPU or DMA must write data on the register SPI\_TXD, data on the register are automatically moved to TX FIFO.

**Read Data:** To read data from RX FIFO, CPU or DMA must access the register SPI\_RXD and data are automatically sent to the register SPI\_RXD.

In CPU or DMA mode, the SPI sends an completed interrupt(the TC bit in SPI Interrupt Status Register) to the processor at the end of each transfer.

#### (1).CPU Mode



**Figure 10- 27. SPI Write/Read Data in CPU Mode**



Figure 10- 28. SPI Write/Read Data in DMA Mode

#### 10.3.4.2. Calibrate Delay Chain

The SPI has one delay chain, which is used to generate delay to make proper timing between internal SPI clock signal and data signals. Delay chain is made up with 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

The steps to calibrate delay chain are as follows:

**Step1:** Enable SPI. In order to calibrate delay chain by operation registers in SPI, SPI must be enabled through AHB reset and AHB clock gating control registers.

**Step2:** Configure a proper clock for SPI. Calibration delay chain is based on the clock for SPI from CCU.

**Step3:** Set proper initial delay value. Write 0xA0 to delay control register to set initial delay value 0x20 to delay chain. Then write 0x0 to delay control register to clear this value.

**Step4:** Write 0x8000 to delay control register to start calibrate delay chain.

**Step5:** Wait until the flag(Bit14 in delay control register) of calibration done is set. The number of delay cells is shown at Bit8~Bit14 in delay control register. The delay time generated by these delay cells is equal to the cycle of SPI clock nearly. This value is the result of calibration.

**Step6:** Calculate the delay time of one delay cell according to the cycle of SPI clock and the result of calibration.

#### 10.3.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI0        | 0x05010000   |
| SPI1        | 0x05011000   |
| SPI2        | 0x05012000   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| SPI_GCR       | 0x0004 | SPI Global Control Register       |
| SPI_TCR       | 0x0008 | SPI Transfer Control Register     |
| SPI_IER       | 0x0010 | SPI Interrupt Control Register    |
| SPI_ISR       | 0x0014 | SPI Interrupt Status Register     |
| SPI_FCR       | 0x0018 | SPI FIFO Control Register         |
| SPI_FSR       | 0x001C | SPI FIFO Status Register          |
| SPI_WCR       | 0x0020 | SPI Wait Clock Counter Register   |
| SPI_SAMP_DL   | 0x0028 | SPI Sample Delay Control Register |
| SPI_MBC       | 0x0030 | SPI Burst Counter Register        |

|                   |        |                                                 |
|-------------------|--------|-------------------------------------------------|
| SPI_MTC           | 0x0034 | SPI Transmit Counter Register                   |
| SPI_BCC           | 0x0038 | SPI Burst Control Register                      |
| SPI_BATCR         | 0x0040 | SPI Bit-Aligned Transfer Configuration Register |
| SPI_3W_CCR        | 0x0044 | SPI Bit-Aligned Clock Configuration Register    |
| SPI_TBR           | 0x0048 | SPI TX Bit Register                             |
| SPI_RBR           | 0x004C | SPI RX Bit Register                             |
| SPI_NDMA_MODE_CTL | 0x0088 | SPI Normal DMA Mode Control Register            |
| SPI_TXD           | 0x0200 | SPI TX Data Register                            |
| SPI_RXD           | 0x0300 | SPI RX Data Register                            |

### 10.3.6. Register Description

#### 10.3.6.1. 0x0004 SPI Global Control Register(Default Value: 0x0000\_0080)

| Offset:0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                                                                                                                              |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31            | R/WAC      | 0x0         | <p>SRST<br/>Soft reset<br/>Writing ‘1’ to this bit will clear the SPI controller, and auto clear to ‘0’ when reset operation completes.<br/>Writing ‘0’ has no effect.</p>                                                                                                          |
| 30:8          | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 7             | R/W        | 0x1         | <p>TP_EN<br/>Transmit Pause Enable<br/>In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br/>0: Normal operation, ignore RXFIFO status<br/>1: Stop transmit data when RXFIFO full<br/>Cannot be written when XCH=1</p> |
| 6:3           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 2             | R/W        | 0x0         | <p>MODE_SELECT<br/>0: Old mode of Sample Timing<br/>1: New mode of Sample Timing<br/>Note: Can't be written when XCH=1</p>                                                                                                                                                          |
| 1             | R/W        | 0x0         | <p>MODE<br/>SPI Function Mode Select<br/>0: Slave mode<br/>1: Master mode<br/>Cannot be written when XCH=1</p>                                                                                                                                                                      |
| 0             | R/W        | 0x0         | <p>EN<br/>SPI Module Enable Control<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                |

|  |  |  |                                                                                     |
|--|--|--|-------------------------------------------------------------------------------------|
|  |  |  | After transforming from bit_mode to byte_mode, it must enable the SPI module again. |
|--|--|--|-------------------------------------------------------------------------------------|

#### 10.3.6.2. 0x0008 SPI Transfer Control Register(Default Value: 0x0000\_0087)

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/WAC      | 0x0         | <p>XCH<br/>Exchange Burst<br/>In master mode it is used to start SPI burst<br/>0: Idle<br/>1: Initiates exchange.<br/>Writing “1” to this bit will start the SPI burst, and will auto clear after finishing the bursts transfer specified by BC. Writing “1” to SRST will also clear this bit.<br/>Writing ‘0’ to this bit has no effect.<br/>Cannot be written when XCH=1.</p>                                                               |
| 30:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15             | R/W        | 0x0         | <p>SDC1<br/>Master Sample Data Control register1<br/>Set this bit to ‘1’ to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.<br/>0 – normal operation, do not delay internal read sample point<br/>1 – delay internal read sample point<br/>Cannot be written when XCH=1.</p> |
| 14             | R/W        | 0x0         | <p>SDDM<br/>Sending Data Delay Mode<br/>0:Normal sending<br/>1:Delay sending<br/>Set the bit to "1" to make the data that should be sent with a delay of half cycle of SPI_CLK in dual IO mode for SPI mode 0.<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                          |
| 13             | R/W        | 0x0         | <p>SDM<br/>Master Sample Data Mode<br/>0: Delay sample mode<br/>1: Normal sample mode<br/>In normal sample mode, SPI master samples the data at the correct edge for each SPI mode;<br/>In delay sample mode, SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.<br/>Cannot be written when XCH=1.</p>                                                                        |
| 12             | R/W        | 0x0         | FBS<br>First Transmit Bit Select<br>0: MSB first                                                                                                                                                                                                                                                                                                                                                                                              |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 1: LSB first<br>Cannot be written when XCH=1.                                                                                                                                                                                                                                                                                                                                                                        |
| 11  | R/W | 0x0 | SDC<br>Master Sample Data Control<br>Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.<br>0: Normal operation, do not delay internal read sample point<br>1: Delay internal read sample point<br>Cannot be written when XCH=1. |
| 10  | R/W | 0x0 | RPSM<br>Rapids Mode Select<br>Select rapid mode for high speed write.<br>0: Normal write mode<br>1: Rapid write mode<br>Cannot be written when XCH=1.                                                                                                                                                                                                                                                                |
| 9   | R/W | 0x0 | DDB<br>Dummy Burst Type<br>0: The bit value of dummy SPI burst is zero<br>1: The bit value of dummy SPI burst is one<br>Cannot be written when XCH=1.                                                                                                                                                                                                                                                                |
| 8   | R/W | 0x0 | DHB<br>Discard Hash Burst<br>In master mode it controls whether discarding unused SPI bursts<br>0: Receiving all SPI bursts in BC period<br>1: Discard unused SPI bursts, only fetching the SPI bursts during dummy burst period. The bursts number is specified by TC.<br>Cannot be written when XCH=1.                                                                                                             |
| 7   | R/W | 0x1 | SS_LEVEL<br>When control SS signal manually (SPI_CTRL_REG.SS_CTRL==1), set this bit to '1' or '0' to control the level of SS signal.<br>0: set SS to low<br>1: set SS to high<br>Cannot be written when XCH=1.                                                                                                                                                                                                       |
| 6   | R/W | 0x0 | SS_OWNER<br>SS Output Owner Select<br>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br>0: SPI controller<br>1: Software<br>Cannot be written when XCH=1.                                                                                                           |
| 5:4 | R/W | 0x0 | SS_SEL<br>SPI Chip Select<br>Select one of four external SPI Master/Slave Devices                                                                                                                                                                                                                                                                                                                                    |

|   |     |     |                                                                                                                                                                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 00: SPI_SS0 will be asserted<br>01: SPI_SS1 will be asserted<br>10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted<br>Cannot be written when XCH=1.                                                                                          |
| 3 | R/W | 0x0 | SSCTL<br><br>In master mode, this bit selects the output wave form for the SPI_SSx signal.<br>Only valid when SS_OWNER = 0.<br>0: SPI_SSx remains asserted between SPI bursts<br>1: Negate SPI_SSx between SPI bursts<br>Cannot be written when XCH=1. |
| 2 | R/W | 0x1 | SPOL<br><br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br>Cannot be written when XCH=1.                                                                                        |
| 1 | R/W | 0x1 | CPOL<br><br>SPI Clock Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br>Cannot be written when XCH=1.                                                                                                     |
| 0 | R/W | 0x1 | CPHA<br><br>SPI Clock/Data Phase Control<br>0: Phase 0 (Leading edge for sample data)<br>1: Phase 1 (Leading edge for setup data)<br>Cannot be written when XCH=1.                                                                                     |

#### 10.3.6.3. 0x0010 SPI Interrupt Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:14          | /          | /           | /                                                                                                                                  |
| 13             | R/W        | 0x0         | SS_INT_EN<br><br>SSI Interrupt Enable<br><br>Chip select signal (SSx) from valid state to invalid state<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | TC_INT_EN<br><br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                    |
| 11             | R/W        | 0x0         | TF_UDR_INT_EN<br><br>TXFIFO Underrun Interrupt Enable<br>0: Disable                                                                |

|    |     |     |                                                                                    |
|----|-----|-----|------------------------------------------------------------------------------------|
|    |     |     | 1: Enable                                                                          |
| 10 | R/W | 0x0 | TF_OVF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 9  | R/W | 0x0 | RF_UDR_INT_EN<br>RXFIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable       |
| 8  | R/W | 0x0 | RF_OVF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 7  | /   | /   | /                                                                                  |
| 6  | R/W | 0x0 | TF_FUL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 5  | R/W | 0x0 | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4  | R/W | 0x0 | TX_ERQ_INT_EN<br>TX FIFO Empty Request Interrupt Enable<br>0: Disable<br>1: Enable |
| 3  | /   | /   | /                                                                                  |
| 2  | R/W | 0x0 | RF_FUL_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 1  | R/W | 0x0 | RX_EMP_INT_EN<br>RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 0  | R/W | 0x0 | RF_RDY_INT_EN<br>RX FIFO Ready Request Interrupt Enable<br>0: Disable<br>1: Enable |

#### 10.3.6.4. 0x0014 SPI Interrupt Status Register(Default Value: 0x0000\_0032)

| Offset: 0x0014 |            | Register Name: SPI_ISR |             |
|----------------|------------|------------------------|-------------|
| Bit            | Read/Write | Default/Hex            | Description |

|       |       |     |                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | /     | /   | /                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | R/W1C | 0x0 | <p>SSI<br/>SS Invalid Interrupt<br/>When SSI is 1, it indicates that SS has changed from valid state to invalid state.<br/>Writing 1 to this bit clears it.</p>                                                                                                                                                                                                          |
| 12    | R/W1C | 0x0 | <p>TC<br/>Transfer Completed<br/>In master mode, it indicates that all bursts specified by BC have been exchanged. In other condition, when set, this bit indicates that all the datas in TXFIFO have been loaded in the Shift register, and the Shift register has shifted out all the bits. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer completed</p> |
| 11    | R/W1C | 0x0 | <p>TF_UDF<br/>TXFIFO Underrun<br/>This bit is set when if the TXFIFO is underrun. Writing 1 to this bit clears it.<br/>0: TXFIFO is not underrun<br/>1: TXFIFO is underrun</p>                                                                                                                                                                                           |
| 10    | R/W1C | 0x0 | <p>TF_OVF<br/>TXFIFO Overflow<br/>This bit is set when if the TXFIFO is overflow. Writing 1 to this bit clears it.<br/>0: TXFIFO is not overflow<br/>1: TXFIFO is overflowed</p>                                                                                                                                                                                         |
| 9     | R/W1C | 0x0 | <p>RX_UDF<br/>RXFIFO Underrun<br/>When set, this bit indicates that RXFIFO has underrun. Writing 1 to this bit clears it.</p>                                                                                                                                                                                                                                            |
| 8     | R/W1C | 0x0 | <p>RX_OVF<br/>RXFIFO Overflow<br/>When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br/>0: RXFIFO is available<br/>1: RXFIFO is overflowed</p>                                                                                                                                                                                   |
| 7     | /     | /   | /                                                                                                                                                                                                                                                                                                                                                                        |
| 6     | R/W1C | 0x0 | <p>TX_FULL<br/>TXFIFO Full<br/>This bit is set when if the TXFIFO is full . Writing 1 to this bit clears it.<br/>0: TXFIFO is not Full<br/>1: TXFIFO is Full</p>                                                                                                                                                                                                         |
| 5     | R/W1C | 0x1 | <p>TX_EMP<br/>TXFIFO Empty<br/>This bit is set if the TXFIFO is empty. Writing 1 to this bit clears it.<br/>0: TXFIFO contains one or more words.<br/>1: TXFIFO is empty</p>                                                                                                                                                                                             |
| 4     | R/W1C | 0x1 | TX_READY                                                                                                                                                                                                                                                                                                                                                                 |

|   |       |     |                                                                                                                                                                                                                                                                                      |
|---|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | <p><b>TXFIFO Ready</b><br/>           0: TX_WL &gt; TX_TRIG_LEVEL<br/>           1: TX_WL &lt;= TX_TRIG_LEVEL<br/>           This bit is set any time if TX_WL &lt;= TX_TRIG_LEVEL. Writing "1" to this bit clears it. TX_WL is the water level of TXFIFO.</p>                       |
| 3 | /     | /   | /                                                                                                                                                                                                                                                                                    |
| 2 | R/W1C | 0x0 | <p><b>RX_FULL</b><br/>           RXFIFO Full<br/>           This bit is set when the RXFIFO is full. Writing 1 to this bit clears it.<br/>           0: Not Full<br/>           1: Full</p>                                                                                          |
| 1 | R/W1C | 0x1 | <p><b>RX_EMP</b><br/>           RXFIFO Empty<br/>           This bit is set when the RXFIFO is empty. Writing 1 to this bit clears it.<br/>           0: Not empty<br/>           1: empty</p>                                                                                       |
| 0 | R/W1C | 0x0 | <p><b>RX_RDY</b><br/>           RXFIFO Ready<br/>           0: RX_WL &lt; RX_TRIG_LEVEL<br/>           1: RX_WL &gt;= RX_TRIG_LEVEL<br/>           This bit is set any time if RX_WL &gt;= RX_TRIG_LEVEL. Writing "1" to this bit clears it. RX_WL is the water level of RXFIFO.</p> |

#### 10.3.6.5. 0x0018 SPI FIFO Control Register(Default Value: 0x0040\_0001)

| Offset: 0x0018 |            | Register Name: SPI_FCR |                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex            | Description                                                                                                                                                                                                                                                                                                                                                                                             |
| 31             | R/WAC      | 0x0                    | <p><b>TX_FIFO_RST</b><br/>           TX FIFO Reset<br/>           Writing '1' to this bit will reset the control portion of the TX FIFO and auto clear to '0' when completing reset operation, writing to '0' has no effect.</p>                                                                                                                                                                        |
| 30             | R/W        | 0x0                    | <p><b>TF_TEST_ENB</b><br/>           TX Test Mode Enable<br/>           0: Disable<br/>           1: Enable<br/> <b>Note:</b> In normal mode, TX FIFO can only be read by SPI controller, writing '1' to this bit will switch TX FIFO read and write function to AHB bus. This bit is used to test the TX FIFO, do not set in normal operation and do not set RF_TEST and TF_TEST at the same time.</p> |
| 29:25          | /          | /                      | /                                                                                                                                                                                                                                                                                                                                                                                                       |
| 24             | R/W        | 0x0                    | <p><b>TF_DRQ_EN</b><br/>           TX FIFO DMA Request Enable<br/>           0: Disable<br/>           1: Enable</p>                                                                                                                                                                                                                                                                                    |

|       |       |      |                                                                                                                                                                                                                                                                                                                                                  |
|-------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:16 | R/W   | 0x40 | TX_TRIG_LEVEL<br>TX FIFO Empty Request Trigger Level                                                                                                                                                                                                                                                                                             |
| 15    | R/WAC | 0x0  | RF_RST<br>RXFIFO Reset<br>Writing '1' to this bit will reset the control portion of the receiver FIFO, and auto clear to '0' when completing reset operation, writing '0' to this bit has no effect.                                                                                                                                             |
| 14    | R/W   | 0x0  | RF_TEST<br>RX Test Mode Enable<br>0: Disable<br>1: Enable<br><b>Note: In normal mode, RX FIFO can only be written by SPI controller, writing '1' to this bit will switch RX FIFO read and write function to AHB bus. This bit is used to test the RX FIFO, donot set in normal operation and donot set RF_TEST and TF_TEST at the same time.</b> |
| 13:9  | /     | /    | /                                                                                                                                                                                                                                                                                                                                                |
| 8     | R/W   | 0x0  | RF_DRQ_EN<br>RX FIFO DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                               |
| 7:0   | R/W   | 0x1  | RX_TRIG_LEVEL<br>RX FIFO Ready Request Trigger Level                                                                                                                                                                                                                                                                                             |

#### 10.3.6.6. 0x001C SPI FIFO Status Register(Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31             | R          | 0x0         | TB_WR<br>TX FIFO Write Buffer Write Enable                                                                                                                                           |
| 30:28          | R          | 0x0         | TB_CNT<br>TX FIFO Write Buffer Counter<br>These bits indicate the number of words in TX FIFO Write Buffer                                                                            |
| 27:24          | /          | /           | /                                                                                                                                                                                    |
| 23:16          | R          | 0x0         | TF_CNT<br>TX FIFO Counter<br>These bits indicate the number of words in TX FIFO<br>0: 0 byte in TX FIFO<br>1: 1 byte in TX FIFO<br>...<br>64: 64 bytes in TX FIFO<br>other: Reserved |
| 15             | R          | 0x0         | RB_WR<br>RX FIFO Read Buffer Write Enable                                                                                                                                            |
| 14:12          | R          | 0x0         | RB_CNT                                                                                                                                                                               |

|      |   |     |                                                                                                                                                                                      |
|------|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |   |     | RX FIFO Read Buffer Counter<br>These bits indicate the number of words in RX FIFO Read Buffer                                                                                        |
| 11:8 | / | /   | /                                                                                                                                                                                    |
| 7:0  | R | 0x0 | RF_CNT<br>RX FIFO Counter<br>These bits indicate the number of words in RX FIFO<br>0: 0 byte in RX FIFO<br>1: 1 byte in RX FIFO<br>...<br>64: 64 bytes in RX FIFO<br>other: Reserved |

#### 10.3.6.7. 0x0020 SPI Wait Clock Register(Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                           |
| 19:16          | R/W        | 0x0         | SWC<br>Dual mode direction switch wait clock counter (for master mode only).<br>Cannot be written when XCH=1.<br>0: No wait states inserted<br>n: n SPI_SCLK wait states inserted<br><b>Note: These bits control the number of wait states to be inserted before start dual data transfer in dual SPI mode. The SPI module counts SPI_SCLK by SWC for delaying next word data transfer.</b> |
| 15:0           | R/W        | 0x0         | WCC<br>Wait Clock Counter (In master mode)<br>Cannot be written when XCH=1.<br>These bits control the number of wait states to be inserted in data transfers.<br>The SPI module counts SPI_SCLK by WCC for delaying next word data transfer.<br>0: No wait states inserted<br>N: N SPI_SCLK wait states inserted                                                                            |

#### 10.3.6.8. 0x0028 SPI Sample Delay Control Register(Default Value: 0x0000\_2000)

| Offset: 0x0028 |            |             | Register Name: SPI_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                                                                                       |

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

#### 10.3.6.9. 0x0030 SPI Master Burst Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SPI_MBC                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                 |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                           |
| 23:0           | R/W        | 0x0         | MBC<br>Master Burst Counter<br>Cannot be written when XCH=1.<br>In master mode, this field specifies the total burst number.<br>0: 0 burst<br>1: 1 burst<br>...<br>N: N bursts<br>Cannot be written when XCH=1.<br><b>Note: Total transfer data, includes the TXD, RXD and dummy burst.</b> |

#### 10.3.6.10. 0x0034 SPI Master Transmit Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SPI_MTC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:24          | /          | /           | /                      |
| 23:0           | R/W        | 0x0         | MWTC                   |

|  |  |  |                                                                                                                                                                                                                                                                                                                                                                                            |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>Master Write Transmit Counter</p> <p>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy burst. For saving bus bandwidth, the dummy burst (all zero bits or all one bits) is sent by SPI Controller automatically.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.3.6.11. 0x0038 SPI Master Burst Control Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                               |
| 29             | R/W        | 0x0         | <p>Quad_EN<br/>Quad_Mode_EN<br/>0: Quad mode disable<br/>1: Quad mode enable</p> <p>Cannot be written when XCH=1.</p> <p><b>Note: Quad mode includes Quad-Input and Quad-Output.</b></p>                                                                                                        |
| 28             | R/W        | 0x0         | <p>DRM<br/>Master Dual Mode RX Enable<br/>0: RX use single-bit mode<br/>1: RX use dual mode</p> <p>Cannot be written when XCH=1.</p> <p>It is only valid when Quad_Mode_EN=0.</p>                                                                                                               |
| 27:24          | R/W        | 0x0         | <p>DBC<br/>Master Dummy Burst Counter</p> <p>In master mode, this field specifies the burst number that should be sent before receive in dual SPI mode. The data does not care by the device.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |
| 23:0           | R/W        | 0x0         | <p>STC<br/>Master Single Mode Transmit Counter</p> <p>In master mode, this field specifies the burst number that should be sent in single mode before automatically sending dummy burst. This is the first transmit counter in all bursts.</p> <p>0: 0 burst<br/>1: 1 burst</p>                 |

|  |  |  |                                                                    |
|--|--|--|--------------------------------------------------------------------|
|  |  |  | <p>...</p> <p>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |
|--|--|--|--------------------------------------------------------------------|

#### 10.3.6.12. 0x0040 SPI Bit-Aligned Transfer Configuration Register(Default Value: 0x0000\_00A0)

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/WAC      | 0x0         | <p>TCE<br/>Transfer Control Enable<br/>In master mode, it is used to start to transfer the serial bits frame, it is only valid when <b>Work Mode Select==0x10/0x11</b>.<br/>0: Idle<br/>1: Initiates transfer<br/>Writing “1” to this bit will start to transfer serial bits frame(the value comes from the <b>SPI TX Bit Register</b> or <b>SPI RX Bit Register</b>), and will auto clear after the bursts transfer completely. Writing ‘0’ to this bit has no effect.</p> |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0: Delay Sample Mode<br/>1: Standard Sample Mode<br/>In Standard Sample Mode, SPI master samples the data at the standard rising edge of SCLK for each SPI mode.<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p>                                                                                                    |
| 29:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in <b>SPI TX Bit Register</b>(or <b>SPI RX Bit Register</b>) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/>It is only valid when <b>Work Mode Select==0x10/0x11</b>.</p>                                                                                                                       |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/>It is only valid when <b>Work Mode Select==0x10/0x11</b>.</p>                                                                                                                                                                                                                                                                                                                   |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 21:16          | R/W        | 0x00        | <p>Configure the length of serial data frame(burst) of RX<br/>000000: 0bit<br/>000001: 1bit<br/>...</p>                                                                                                                                                                                                                                                                                                                                                                     |

|       |     |      |                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 100000: 32bits<br>Other values: reserved<br>It is only valid when <b>Work Mode Select==0x10/0x11</b> , and cannot be written when TCE=1.                                                                                                                                                                                                                                                              |
| 15:14 | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:8  | R/W | 0x00 | Configure the length of serial data frame(burst) of TX<br>000000: 0bit<br>000001: 1bit<br>...<br>100000: 32bits<br>Other values: reserved<br>It is only valid when <b>Work Mode Select==0x10/0x11</b> , and cannot be written when TCE=1.                                                                                                                                                             |
| 7     | R/W | 0x1  | SS_LEVEL<br>When control SS signal manually , set this bit to '1' or '0' to control the level of SS signal.<br>0: Set SS to low<br>1: Set SS to high<br>It is only valid when <b>Work Mode Select==0x10/0x11</b> , and only <b>work in Mode0</b> , cannot be written when TCE=1.                                                                                                                      |
| 6     | R/W | 0x0  | SS_OWNER<br>SS Output Owner Select<br>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br>0: SPI controller<br>1: Software<br>It is only valid when <b>Work Mode Select==0x10/0x11</b> , and only <b>work in Mode0</b> , cannot be written when TCE=1. |
| 5     | R/W | 0x1  | SPOL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br>It is only valid when <b>Work Mode Select==0x10/0x11</b> , and only <b>work in Mode0</b> , cannot be written when TCE=1.                                                                                                                                                |
| 4     | /   | /    | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:2   | R/W | 0x0  | SS_SEL<br>SPI Chip Select<br>Select one of four external SPI Master/Slave Devices<br>00: SPI_SS0 will be asserted<br>01: SPI_SS1 will be asserted<br>10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted<br>It is only valid when <b>Work Mode Select= =0x10/0x11</b> , and only <b>work in Mode0</b> , cannot be written when TCE=1.                                                        |

|     |     |     |                                                                                                                                                                                                                                                             |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0 | R/W | 0x0 | Work Mode Select<br>00: Data frame is byte aligned in standard SPI, dual-output/dual input SPI, dual IO SPI and quad-output/quad-input SPI.<br>01: Reserved<br>10: Data frame is bit aligned in 3-wire SPI<br>11: Data frame is bit aligned in standard SPI |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.3.6.13. 0x0044 SPI Bit-Aligned Clock Configuration Register(Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SPI_BA_CCR                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                        |
| 7:0            | R/W        | 0x0         | CDR_N<br>Clock Divide Rate (Master Mode Only)<br>The SPI_SCLK is determined according to the following equation: SPI_CLK = Source_CLK / (2*(CDR_N + 1)). |


**NOTE**

This register is only valid when **Work Mode Select==0x10/0x11**.

#### 10.3.6.14. 0x0048 SPI TX Bit Register(Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SPI_TBR                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:0           | R/W        | 0x0         | VTB<br>The Value of the Transmit Bits<br>This register is used to store the value of the transmitted serial data frame.<br>In the process of transmission, the LSB is transmitted first. |


**NOTE**

This register is only valid when **Work Mode Select==0x10/0x11**.

#### 10.3.6.15. 0x004C SPI RX Bit Register(Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | VRB<br>The Value of the Receive Bits<br>This register is used to store the value of the received serial data frame.<br>In the process of transmission, the LSB is transmitted first. |


**NOTE**

This register is only valid when **Work Mode Select==0x10/0x11**.

#### 10.3.6.16. 0x0088 SPI Normal DMA Mode Control Register(Default Value: 0x0000\_00E5)

| Offset: 0x0088 |            |             | Register Name: NDFC_NDMA_MODE_CTL                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                             |
| 7:6            | R/W        | 0x11        | 00:dma_active is low<br>01:dma_active is high<br>10:dma_active is controlled by dma_request(DRQ)<br>11:dma_active is controlled by controller |
| 5              | R/W        | 0x1         | 0: active fall do not care ack<br>1: active fall must after detect ack is high                                                                |
| 4:0            | R/W        | 0x05        | Delay Cycles<br>The counts of hold cycles from DMA last signal high to dma_active high                                                        |

#### 10.3.6.17. 0x0200 SPI TX Data Register(Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0           | R/W        | 0x0         | TDATA<br>Transmit Data<br>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are rooms in TXFIFO, one burst data is written to TXFIFO and the depth is increased by 1. In half-word accessing method, two SPI burst data are written and the TXFIFO depth is increased by 2. In word accessing method, four SPI burst data are written and the TXFIFO depth is increased by 4.<br><b>Note: This address is writable-only if TF_TEST is '0', and if TF_TEST is set to '1', this address is readable and writable to test the TX FIFO through the AHB bus.</b> |

#### 10.3.6.18. 0x0300 SPI RX Data Register(Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: SPI_RXD                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                       |
| 31:0           | R          | 0x0         | RDATA<br>Receive Data<br>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are data in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In half-word accessing method, two SPI bursts are returned and the RXFIFO depth is decreased by 2. In word |

|  |  |                                                                                                                                                                                                                                                                          |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.<br><b>Note:</b> This address is readable-only if RF_TEST is '0', and if RF_TEST is set to '1', this address is readable and writable to test the RX FIFO through the AHB bus. |
|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Confidential

## 10.4. USB2.0 OTG

### 10.4.1. Overview

The USB2.0 OTG is a dual-role device controller, which supports both device and host functions which can also be configured as a Host-only or Device-only controller, fully compliant with the USB2.0 Specification. It can support high-speed (HS, 480 Mbit/s), full-speed (FS, 12 Mbit/s), and low-speed (LS, 1.5 Mbit/s) transfers in Host mode. It can support high-speed (HS, 480 Mbit/s), and full-speed (FS, 12 Mbit/s) in Device mode. Standard USB transceiver can be used through its UTMI+PHY Level3 interface. The UTMI+PHY interface is bidirectional with 8-bit data bus. For saving CPU bandwidth, USB-OTG DMA interface can support external DMA controller to take care of the data transfer between the memory and USB-OTG FIFO. The USB-OTG core also supports USB power saving functions.

The USB2.0 OTG has the following features:

- Complies with USB2.0 Specification
- Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s), and Low-Speed (LS, 1.5 Mbit/s) in Host mode
- Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) in Device mode
- Supports the UTMI+ Level 3 interface. The 8-bit bidirectional data buses are used
- Supports bi-directional endpoint0 for Control transfer
- Supports up to 10 User-Configurable Endpoints for Bulk, Isochronous and Interrupt bi-directional transfer
- Supports up to (8 KB+64 Bytes) FIFO for all EPs (including EP0)
- 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 mode
- Includes automatic ping capabilities
- Soft connect/disconnect function
- Performs all transaction scheduling in hardware
- Power optimization and power management capabilities
- Includes interface to an external Normal DMA controller for every EPs
- Device and Host controller share a 4 KB sram and a physical PHY

### 10.4.2. Block Diagram

Figure 10-29 shows the block diagram of USB2.0 OTG Controller.



Figure 10- 29. USB2.0 OTG Controller Block Diagram

#### 10.4.3. Operations and Functional Descriptions

##### 10.4.3.1. External Signals

Table 10- 13. USB2.0 OTG External Signals

| Signal  | Description                             | Type  |
|---------|-----------------------------------------|-------|
| USBO_DP | USB2.0 OTG differential signal positive | A I/O |
| USBO_DM | USB2.0 OTG differential signal negative | A I/O |
| VCC_USB | USB analog power supply                 | P     |
| VDD_USB | USB digital power supply                | P     |

#### 10.4.3.2. Controller and PHY Connection Diagram



Figure 10- 30. USB2.0 OTG Controller and PHY Connection Diagram

#### 10.4.3.3. Function Implementation

Refer to USB2.0 Specification.

## 10.5. USB2.0 Host Controller

### 10.5.1. Overview

USB Host Controller is fully compliant with the USB 2.0 specification, Enhanced Host Controller Interface (EHCI) Specification, Revision 1.0, and the Open Host Controller Interface (OHCI) Specification Release 1.0a. The controller supports high-speed, 480Mbit/s transfers (40 times faster than USB 1.1 full-speed mode) using an EHCI Host Controller, as well as full and low speeds through one or more integrated OHCI Host Controllers.

The USB2.0 host controller includes the following features:

- Supports industry-standard AMBA High-Performance Bus (AHB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Supports 32-bit Little Endian AMBA AHB Slave Bus for Register Access
- Supports 32-bit Little Endian AMBA AHB Master Bus for Memory Access
- Including an internal DMA Controller for data transfer with memory
- Complies with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the 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. The 8-bit bidirectional data buses are used
- Supports only 1 USB Root Port shared between EHCI and OHCI

### 10.5.2. Block Diagram

Figure 10-31 shows the block diagram of USB2.0 HOST Controller.



Figure 10- 31. USB2.0 Host Controller Block Diagram

### 10.5.3. Operations and Functional Descriptions

#### 10.5.3.1. External Signals

Table 10- 14. USB2.0 HOST External Signals

| Signal  | Description                              | Type |
|---------|------------------------------------------|------|
| USB1_DP | USB2.0 HOST differential signal positive | AI/O |
| USB1_DM | USB2.0 HOST differential signal negative | AI/O |
| VCC_USB | USB analog power supply                  | P    |
| VDD_USB | USB digital power supply                 | P    |

#### 10.5.3.2. Controller and PHY Connection Diagram



Figure 10- 32. USB2.0 HOST Controller and PHY Connection Diagram

#### 10.5.3.3. Function Implementation

Refer to USB2.0 Specification, Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the Open Host Controller Interface (OHCI) Specification, Version 1.0a.

### 10.5.4. USB Host Register List

| Module Name | Base Address |
|-------------|--------------|
| USB1        | 0x05200000   |

| Register Name                                     | Offset | Description                                     |
|---------------------------------------------------|--------|-------------------------------------------------|
| <b>EHCI Capability Register</b>                   |        |                                                 |
| E_CAPLENGTH                                       | 0x0000 | EHCI Capability Register Length Register        |
| E_HCIVERSION                                      | 0x0002 | EHCI Host Interface Version Number Register     |
| E_HCSPARAMS                                       | 0x0004 | EHCI Host Control Structural Parameter Register |
| E_HCCPARAMS                                       | 0x0008 | EHCI Host Control Capability Parameter Register |
| E_HCSPPORTROUTE                                   | 0x000C | EHCI Companion Port Route Description           |
| <b>EHCI Operational Register</b>                  |        |                                                 |
| E_USBCMD                                          | 0x0010 | EHCI USB Command Register                       |
| E_USBSTS                                          | 0x0014 | EHCI USB Status Register                        |
| E_USBINTR                                         | 0x0018 | EHCI USB Interrupt Enable Register              |
| E_FRINDEX                                         | 0x001C | EHCI USB Frame Index Register                   |
| E_CTRLDSSEGMENT                                   | 0x0020 | EHCI 4G Segment Selector Register               |
| E_PERIODICLISTBASE                                | 0x0024 | EHCI Frame List Base Address Register           |
| E_ASYNCLISTADDR                                   | 0x0028 | EHCI Next Asynchronous List Address Register    |
| E_CONFIGFLAG                                      | 0x0050 | EHCI Configured Flag Register                   |
| E_PORTSC                                          | 0x0054 | EHCI Port Status/Control Register               |
| <b>OHCI Control and Status Partition Register</b> |        |                                                 |
| O_HcRevision                                      | 0x0400 | OHCI Revision Register                          |
| O_HcControl                                       | 0x0404 | OHCI Control Register                           |
| O_HcCommandStatus                                 | 0x0408 | OHCI Command Status Register                    |
| O_HcInterruptStatus                               | 0x040C | OHCI Interrupt Status Register                  |
| O_HcInterruptEnable                               | 0x0410 | OHCI Interrupt Enable Register                  |
| O_HcInterruptDisable                              | 0x0414 | OHCI Interrupt Disable Register                 |
| <b>OHCI Memory Pointer Partition Register</b>     |        |                                                 |
| O_HcHCCA                                          | 0x0418 | OHCI HCCA Base                                  |
| O_HcPeriodCurrentED                               | 0x041C | OHCI Period Current ED Base                     |
| O_HcControlHeadED                                 | 0x0420 | OHCI Control Head ED Base                       |
| O_HcControlCurrentED                              | 0x0424 | OHCI Control Current ED Base                    |
| O_HcBulkHeadED                                    | 0x0428 | OHCI Bulk Head ED Base                          |
| O_HcBulkCurrentED                                 | 0x042C | OHCI Bulk Current ED Base                       |
| O_HcDoneHead                                      | 0x0430 | OHCI Done Head Base                             |
| <b>OHCI Frame Counter Partition Register</b>      |        |                                                 |
| O_HcFmInterval                                    | 0x0434 | OHCI Frame Interval Register                    |
| O_HcFmRemaining                                   | 0x0438 | OHCI Frame Remaining Register                   |
| O_HcFmNumber                                      | 0x043C | OHCI Frame Number Register                      |
| O_HcPeriodicStart                                 | 0x0440 | OHCI Periodic Start Register                    |
| O_HcLSThreshold                                   | 0x0444 | OHCI LS Threshold Register                      |
| <b>OHCI Root Hub Partition Register</b>           |        |                                                 |
| O_HcRhDescriptorA                                 | 0x0448 | OHCI Root Hub Descriptor Register A             |
| O_HcRhDescriptorB                                 | 0x044C | OHCI Root Hub Descriptor Register B             |
| O_HcRhStatus                                      | 0x0450 | OHCI Root Hub Status Register                   |
| O_HcRhPortStatus                                  | 0x0454 | OHCI Root Hub Port Status Register              |
| <b>HCI Controller and PHY Interface Register</b>  |        |                                                 |

|                              |        |                                       |
|------------------------------|--------|---------------------------------------|
| HCI_Interface                | 0x0800 | HCI Interface Register                |
| HCI_CTRL3                    | 0x0808 | HCI Control Register                  |
| PHY_Control                  | 0x0810 | PHY Control Register                  |
| HSIC_PHY_Tune1               | 0x081C | HSIC PHY Tune1 Register               |
| HSIC_PHY_Tune2               | 0x0820 | HSIC PHY Tune2 Register               |
| HSIC_PHY_Tune3               | 0x0824 | HSIC PHY Tune3 Register               |
| HCI SIE Port Disable Control | 0x0828 | HCI SIE Port Disable Control Register |

### 10.5.5. EHCI Register Description

#### 10.5.5.1. 0x0000 EHCI Identification Register(Default Value:0x10)

| Offset:0x0000 |            |             | Register Name: CAPLENGTH                                                                                                                         |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                      |
| 7:0           | R          | 0x10        | <b>CAPLENGTH</b><br>The value in these bits indicates an offset to add to register base to find the beginning of the Operational Register Space. |

#### 10.5.5.2. 0x0002 EHCI Host Interface Version Number Register(Default Value:0x0100)

| Offset: 0x0002 |            |             | Register Name: HCIVERSION                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 15:0           | R          | 0x0100      | <b>HCIVERSION</b><br>This is a 16-bit register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |

#### 10.5.5.3. 0x0004 EHCI Host Control Structural Parameter Register(Default Value:0x0000\_0004)

| Offset: 0x0004 |            |             | Register Name: HCSPARAMS                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 31:24          | /          | /           | /                                                                                                                                                                                                           |
| 23:20          | R          | 0x0         | <b>Debug Port Number</b><br>This register identifies which of the host controller ports is the debug port.<br>The value is the port number (one based) of the debug port.<br>This field will always be '0'. |
| 19:16          | /          | /           | /                                                                                                                                                                                                           |
| 15:12          | R          | 0x0         | <b>Number of Companion Controller (N_CC)</b><br>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion |

|       |                                                                                                                                                                                         |     | host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).<br>This field will always be '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------|
| 11:8  | R                                                                                                                                                                                       | 0x0 | <b>Number of Port per Companion Controller(N_PCC)</b><br>This field indicates the number of ports supported per companion host controller. It is used to indicate the port routing configuration to system software.<br>This field will always fix with '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 7     | R                                                                                                                                                                                       | 0x0 | <b>Port Routing Rules</b><br>This field indicates the method used by this implementation for how all ports are mapped to companion controllers. The value of this field has the following interpretation:<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <th>Value</th> <th>Meaning</th> </tr> <tr> <td>0</td> <td>The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on.</td> </tr> <tr> <td>1</td> <td>The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.</td> </tr> </table><br>This field will always be '0'. | Value | Meaning | 0 | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. | 1 | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array. |
| Value | Meaning                                                                                                                                                                                 |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 0     | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 1     | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.                                                                                    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 6:4   | /                                                                                                                                                                                       | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 3:0   | R                                                                                                                                                                                       | 0x1 | <b>N_PORTS</b><br>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.<br>This field is always 1.                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |

#### 10.5.5.4. 0x0008 EHCI Host Control Capability Parameter Register(Default Value:0x0000\_0008)

| Offset: 0x0008 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:8           | R          | 0x0         | <b>EHCI Extended Capabilities Pointer (EECP)</b><br>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.<br>The value of this field is always '00b'. |
| 7:4            | R          | 0x0         | <b>Isochronous Scheduling Threshold</b><br>This field indicates, relative to the current position of the executing host                                                                                                                                                                                                                                                                                                                                                                             |

|   |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |     | controller, where software can reliably update the isochronous schedule. When bit[7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures(one or more) before flushing the state. When bit[7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.                                                                                                                                            |
| 3 | R | 0x1 | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2 | R | 0x0 | <b>Asynchronous Schedule Park Capability</b><br>If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.                                                                                                                                                                          |
| 1 | R | 0x0 | <b>Programmable Frame List Flag</b><br>If this bit is set to a zero, then system software must use a frame list length of 1024 elements with this host controller. The USBCMD register Frame List Size field is a read-only register and should be set to zero.<br>If set to 1, then system software can specify and use the frame list in the USBCMD register Frame List Size field to configure the host controller.<br>The frame list must always aligned on a 4K page boundary. This requirement ensures that the frame list is always physically contiguous. |
| 0 | / | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 10.5.5.5. 0x000C EHCI Companion Port Route Description(Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: HCSP-PORTROUTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:0           | R          | 0x0         | <b>HCSP-PORTROUTE</b><br>This optional field is valid only if Port Routing Rules field in HCSPARAMS register is set to a one.<br>This field is used to allow a host controller implementation to explicitly describe to which companion host controller each implemented port is mapped. This field is a 15-element nibble array (each 4 bit is one array element). Each array location corresponds one-to-one with a physical port provided by the host controller (e.g. PORTROUTE [0] corresponds to the first PORTSC port, PORTROUTE [1] to the second PORTSC port, etc.). The value of each element indicates to which the companion host controllers this port is routed. Only the first N_PORTS elements have valid information. A value of zero indicates that the port is routed to the lowest numbered function companion host controller. A value of one indicates that the port is routed to the next lowest numbered function companion host controller, and so on. |

## 10.5.5.6. 0x0010 EHCI USB Command Register(Default Value:0x0008\_0000)

| Offset: 0x0010 |                                         |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
|----------------|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------|------|----------|------|---------------|------|---------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| Bit            | Read/Write                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 31:24          | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 23:16          | R/W                                     | 0x08        | <p><b>Interrupt Threshold Control</b><br/> The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <tr> <th>Value</th><th>Minimum Interrupt Interval</th></tr> <tr> <td>0x00</td><td>Reserved</td></tr> <tr> <td>0x01</td><td>1 micro-frame</td></tr> <tr> <td>0x02</td><td>2 micro-frame</td></tr> <tr> <td>0x04</td><td>4 micro-frame</td></tr> <tr> <td>0x08</td><td>8 micro-frame(default, equates to 1 ms)</td></tr> <tr> <td>0x10</td><td>16 micro-frame(2ms)</td></tr> <tr> <td>0x20</td><td>32 micro-frame(4ms)</td></tr> <tr> <td>0x40</td><td>64 micro-frame(8ms)</td></tr> </table> <p>Any other value in this register yields undefined results.<br/> The default value in this field is 0x08 .<br/> Software modifications to this bit while HC Halted bit is equal to zero results in undefined behavior.</p> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame | 0x04 | 4 micro-frame | 0x08 | 8 micro-frame(default, equates to 1 ms) | 0x10 | 16 micro-frame(2ms) | 0x20 | 32 micro-frame(4ms) | 0x40 | 64 micro-frame(8ms) |
| Value          | Minimum Interrupt Interval              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x00           | Reserved                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x01           | 1 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x02           | 2 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x04           | 4 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x08           | 8 micro-frame(default, equates to 1 ms) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x10           | 16 micro-frame(2ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x20           | 32 micro-frame(4ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x40           | 64 micro-frame(8ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 15:12          | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 11             | R                                       | 0x0         | <p><b>Asynchronous Schedule Park Mode Enable(OPTIONAL)</b><br/> If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 10             | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 9:8            | R                                       | 0x0         | <p><b>Asynchronous Schedule Park Mode Count(OPTIONAL)</b><br/> Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this field defaults to 0x3 and is W/R. Otherwise it defaults to zero and is R. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the Asynchronous schedule before continuing traversal of the Asynchronous schedule.<br/> Valid value are 0x1 to 0x3. Software must not write a zero to this bit when Park Mode Enable is a one as it will result in undefined behavior.</p>                                                                                                                                                                                                                                                                                                                                                            |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 7              | R/W                                     | 0x0         | <p><b>Light Host Controller Reset(OPTIONAL)</b><br/> This control bit is not required.<br/> If implemented, it allows the driver to reset the EHCI controller without affecting the state of the ports or relationship to the companion host controllers. For example, the PORSTC registers should not be reset to their</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |

|           |                                                                    |     | <p>default values and the CF bit setting should not go to zero (retaining port ownership relationships).</p> <p>A host software read of this bit as zero indicates the Light Host Controller Reset has completed and it is safe for software to re-initialize the host controller. A host software read of this bit as a one indicates the Light Host</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
|-----------|--------------------------------------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-----|-------------------------------------------|-----|--------------------------------------------------------------------|-----|-----------------------------------------------------------|-----|----------|
| 6         | R/W                                                                | 0x0 | <p><b>Interrupt on Async Advance Doorbell</b></p> <p>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.</p> <p>When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS. if the Interrupt on Async Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p> |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 5         | R/W                                                                | 0x0 | <p><b>Asynchronous Schedule Enable</b></p> <p>This bit controls whether the host controller skips processing the Asynchronous Schedule. Values mean:</p> <table border="1"> <tr> <th>Bit Value</th><th>Meaning</th></tr> <tr> <td>0</td><td>Do not process the Asynchronous Schedule.</td></tr> <tr> <td>1</td><td>Use the ASYNLISTADDR register to access the Asynchronous Schedule.</td></tr> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit Value | Meaning | 0   | Do not process the Asynchronous Schedule. | 1   | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |     |                                                           |     |          |
| Bit Value | Meaning                                                            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 0         | Do not process the Asynchronous Schedule.                          |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 1         | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 4         | R/W                                                                | 0x0 | <p><b>Periodic Schedule Enable</b></p> <p>This bit controls whether the host controller skips processing the Periodic Schedule. Values mean:</p> <table border="1"> <tr> <th>Bit Value</th><th>Meaning</th></tr> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                               | Bit Value | Meaning | 0   | Do not process the Periodic Schedule.     | 1   | Use the PERIODICLISTBASE register to access the Periodic Schedule. |     |                                                           |     |          |
| Bit Value | Meaning                                                            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 0         | Do not process the Periodic Schedule.                              |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 1         | Use the PERIODICLISTBASE register to access the Periodic Schedule. |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 3:2       | R/W                                                                | 0x0 | <p><b>Frame List Size</b></p> <p>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This field specifies the size of the Frame list. The size the frame list controls which bits in the Frame Index Register should be used for the Frame List Current index. Values mean:</p> <table border="1"> <tr> <th>Bits</th><th>Meaning</th></tr> <tr> <td>00b</td><td>1024 elements(4096bytes)Default value</td></tr> <tr> <td>01b</td><td>512 elements(2048bytes)</td></tr> <tr> <td>10b</td><td>256 elements(1024bytes)For resource-constrained condition</td></tr> <tr> <td>11b</td><td>reserved</td></tr> </table> <p>The default value is '00b'.</p>                                                                                                                                                                         | Bits      | Meaning | 00b | 1024 elements(4096bytes)Default value     | 01b | 512 elements(2048bytes)                                            | 10b | 256 elements(1024bytes)For resource-constrained condition | 11b | reserved |
| Bits      | Meaning                                                            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 00b       | 1024 elements(4096bytes)Default value                              |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 01b       | 512 elements(2048bytes)                                            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 10b       | 256 elements(1024bytes)For resource-constrained condition          |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 11b       | reserved                                                           |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |

|   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | <b>Host Controller Reset</b><br>This control bit is used by software to reset the host controller. The effects of this on Root Hub registers are similar to a Chip Hardware Reset.<br>When software writes a one to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports.<br>All operational registers, including port registers and port state machines are set to their initial values. Port ownership reverts to the companion host controller(s). Software must reinitialize the host controller as described in Section 4.1 of the CHEI Specification in order to return the host controller to an operational state.<br>This bit is set to zero by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.<br>Software should not set this bit to a one when the HC Halted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior. |
| 0 | R/W | 0x0 | <b>Run/Stop</b><br>When set to a 1, the Host Controller proceeds with execution of the schedule. When set to 0, the Host Controller completes the current and any actively pipelined transactions on the USB and then halts. The Host Controller must halt within 16 micro-frames after software clears this bit.<br>The HC Halted bit indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.<br>Software must not write a one to this field unless the Host Controller is in the Halt State.<br>The default value is 0x0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 10.5.5.7. 0x0014 EHCI USB Status Register(Default Value:0x0000\_1000)

| Offset: 0x0014 |            |             | Register Name: USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15             | R          | 0x0         | <b>Asynchronous Schedule Status</b><br>The bit reports the current real status of Asynchronous Schedule. If this bit is a zero then the status of the Asynchronous Schedule is disabled. If this bit is a one then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0). |
| 14             | R          | 0x0         | <b>Periodic Schedule Status</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

|      |      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |      |     | The bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled. If this bit is a one then the status of the Periodic Schedule is enabled. The Host Controller is not required to <i>immediately</i> disable or enable the Periodic Schedule when software transitions the <i>Periodic Schedule Enable</i> bit in the USBCMD register. When this bit and the <i>Periodic Schedule Enable</i> bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0). |
| 13   | R    | 0x0 | <b>Reclamation</b><br>This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12   | R    | 0x1 | <b>HC Halted</b><br>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller Sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller Hardware (e.g. internal error).<br>The default value is '1'.                                                                                                                                                                                                                                                   |
| 11:6 | /    | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5    | R/WC | 0x0 | <b>Interrupt on Async Advance</b><br>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.                                                                                                                                                                                                                        |
| 4    | R/WC | 0x0 | <b>Host System Error</b><br>The Host Controller set this bit to 1 when a serious error occurs during a host system access involving the Host Controller module. When this error occurs, the Host Controller clears the Run/Stop bit in the Command register to prevent further execution of the scheduled TDs.                                                                                                                                                                                                                                                 |
| 3    | R/WC | 0x0 | <b>Frame List Rollover</b><br>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX [12] toggles.                                                                                                        |
| 2    | R/WC | 0x0 | <b>Port Change Detect</b><br>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to zero has a change bit transition from a zero to a one or a Force Port Resume bit transition from a zero to a one as a result of a J-K transition detected on a suspended port. This bit will also be set as a result of the Connect Status Chang being set to a one after system software has relinquished ownership of a connected port by writing a one to a port's Port Owner bit.                                             |
| 1    | R/WC | 0x0 | <b>USB Error Interrupt(USBERRINT)</b><br>The Host Controller sets this bit to 1 when completion of USB transaction results in an error condition(e.g. error counter underflow).If the TD on which                                                                                                                                                                                                                                                                                                                                                              |

|   |      |     |                                                                                                                                                                                                                                                                                                                                                                                  |
|---|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |     | the error interrupt occurred also had its IOC bit set, both.<br>This bit and USBINT bit are set.                                                                                                                                                                                                                                                                                 |
| 0 | R/WC | 0x0 | <p><b>USB Interrupt(USBINT)</b></p> <p>The Host Controller sets this bit to a one on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.</p> <p>The Host Controller also sets this bit to 1 when a short packet is detected (actual number of bytes received was less than the expected number of bytes)</p> |

#### 10.5.5.8. 0x0018 EHCI USB Interrupt Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: USBINTR                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                        |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                  |
| 5              | R/W        | 0x0         | <p><b>Interrupt on Async Advance Enable</b></p> <p>When this bit is 1, and the Interrupt on Async Advance bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the Interrupt on Async Advance bit.</p> |
| 4              | R/W        | 0x0         | <p><b>Host System Error Enable</b></p> <p>When this bit is 1, and the Host System Error Status bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Host System Error bit.</p>                                                     |
| 3              | R/W        | 0x0         | <p><b>Frame List Rollover Enable</b></p> <p>When this bit is 1, and the Frame List Rollover bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit.</p>                                                      |
| 2              | R/W        | 0x0         | <p><b>Port Change Interrupt Enable</b></p> <p>When this bit is 1, and the Port Chang Detect bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Port Chang Detect bit.</p>                                                        |
| 1              | R/W        | 0x0         | <p><b>USB Error Interrupt Enable</b></p> <p>When this bit is 1, and the USBERRINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBERRINT bit.</p>                                          |
| 0              | R/W        | 0x0         | <p><b>USB Interrupt Enable</b></p> <p>When this bit is 1, and the USBINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the USBINT bit</p>                                                       |

#### 10.5.5.9. 0x001C EHCI Frame Index Register(Default Value:0x0000\_0000)

| Offset: 0x001C          |                 |             | Register Name: FRINDEX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
|-------------------------|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|---|-----|------|----|-----|-----|----|-----|-----|----|-----|----------|--|
| Bit                     | Read/Write      | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 31:14                   | /               | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 13:0                    | R/W             | 0           | <p><b>Frame Index</b></p> <p>The value in this register increment at the end of each time frame (e.g. micro-frame). Bits[N:3] are used for the Frame List current index. It means that each location of the frame list is accessed 8 times(frames or Micro-frames) before moving to the next index. The following illustrates values of N based on the value of the Frame List Size field in the USBCMD register.</p> <table border="1"> <thead> <tr> <th>USBCMD[Frame List Size]</th> <th>Number Elements</th> <th>N</th> </tr> </thead> <tbody> <tr> <td>00b</td> <td>1024</td> <td>12</td> </tr> <tr> <td>01b</td> <td>512</td> <td>11</td> </tr> <tr> <td>10b</td> <td>256</td> <td>10</td> </tr> <tr> <td>11b</td> <td>Reserved</td> <td></td> </tr> </tbody> </table> | USBCMD[Frame List Size] | Number Elements | N | 00b | 1024 | 12 | 01b | 512 | 11 | 10b | 256 | 10 | 11b | Reserved |  |
| USBCMD[Frame List Size] | Number Elements | N           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 00b                     | 1024            | 12          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 01b                     | 512             | 11          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 10b                     | 256             | 10          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 11b                     | Reserved        |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |


**NOTE**

This register must be written as a DWord. Byte writes produce undefined results.

#### 10.5.5.10. 0x0024 EHCI Periodic Frame List Base Address Register(Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: PERIODICLISTBASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:12          | R/W        | 0x0         | <p><b>Base Address</b></p> <p>These bits correspond to memory address signals [31:12], respectively.</p> <p>This register contains the beginning address of the Periodic Frame List in the system memory.</p> <p>System software loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4 Kbyte aligned. The contents of this register are combined with the Frame Index Register (FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence.</p> |
| 11:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |


**NOTE**

Writes must be Dword Writes.

#### 10.5.5.11. 0x0028 EHCI Current Asynchronous List Address Register(Default Value:0x0000\_0000)

| Offset: 0x0028 | Register Name: ASYNCLISTADDR |
|----------------|------------------------------|
|----------------|------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                              |
|------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:5 | R/W        | 0x0         | <b>Link Pointer (LP)</b><br>This field contains the address of the next asynchronous queue head to be executed.<br>These bits correspond to memory address signals [31:5], respectively. |
| 4:0  | /          | /           | /                                                                                                                                                                                        |

**NOTE**

Write must be DWord Writes.

#### 10.5.5.12. 0x0050 EHCI Configure Flag Register(Default Value:0x0000\_0000)

| Offset: 0x0050 |                                                                                                            |             | Register Name: CONFIGFLAG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                            |   |                                                                             |
|----------------|------------------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                 | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                            |   |                                                                             |
| 31:1           | /                                                                                                          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                                            |   |                                                                             |
| 0              | R/W                                                                                                        | 0x0         | <b>Configure Flag(CF)</b><br>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic as follow:<br><table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Port routing control logic default-routs each port to an implementation dependent classic host controller.</td> </tr> <tr> <td>1</td> <td>Port routing control logic default-routs all ports to this host controller.</td> </tr> </tbody> </table> The default value of this field is '0'. | Value | Meaning | 0 | Port routing control logic default-routs each port to an implementation dependent classic host controller. | 1 | Port routing control logic default-routs all ports to this host controller. |
| Value          | Meaning                                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                            |   |                                                                             |
| 0              | Port routing control logic default-routs each port to an implementation dependent classic host controller. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                            |   |                                                                             |
| 1              | Port routing control logic default-routs all ports to this host controller.                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                            |   |                                                                             |

**NOTE**

This register is not used in the normal implementation.

#### 10.5.5.13. 0x0054 EHCI Port Status and Control Register(Default Value:0x0000\_2000)

| Offset: 0x0054 |            |             | Register Name: PORTSC                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 31:22          | /          | /           | /                                                                                                                                                                                                                                          |
| 21             | R/W        | 0x0         | <b>Wake on Disconnect Enable(WKDSNNT_E)</b><br>Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br>This field is zero if Port Power is zero.<br>The default value in this field is '0'. |
| 20             | R/W        | 0x0         | <b>Wake on Connect Enable(WKCNNT_E)</b><br>Writing this bit to a one enable the port to be sensitive to device connects as wake-up events.                                                                                                 |

|             |                                           |                                              | This field is zero if Port Power is zero.<br>The default value in this field is '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
|-------------|-------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|----------------|-------------------------------------------|-------|-------------------------------------------|-------|--------------|-------------------------------------------|--------------|---------|----------------------------------------------|-------|-------------------|-------------------------------------------|----------|
| 19:16       | R/W                                       | 0x0                                          | <p><b>Port Test Control</b></p> <p>The value in this field specifies the test mode of the port. The encoding of the test mode bits are as follows:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Test Mode</th></tr> </thead> <tbody> <tr><td>0000b</td><td>The port is NOT operating in a test mode.</td></tr> <tr><td>0001b</td><td>Test J_STATE</td></tr> <tr><td>0010b</td><td>Test K_STATE</td></tr> <tr><td>0011b</td><td>Test SEO_NAK</td></tr> <tr><td>0100b</td><td>Test Packet</td></tr> <tr><td>0101b</td><td>Test FORCE_ENABLE</td></tr> <tr><td>0110b-1111b</td><td>Reserved</td></tr> </tbody> </table> <p>The default value in this field is '0000b'.</p>                                                                                                                                                                                                                                                                                          | Bits       | Test Mode | 0000b          | The port is NOT operating in a test mode. | 0001b | Test J_STATE                              | 0010b | Test K_STATE | 0011b                                     | Test SEO_NAK | 0100b   | Test Packet                                  | 0101b | Test FORCE_ENABLE | 0110b-1111b                               | Reserved |
| Bits        | Test Mode                                 |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0000b       | The port is NOT operating in a test mode. |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0001b       | Test J_STATE                              |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0010b       | Test K_STATE                              |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0011b       | Test SEO_NAK                              |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0100b       | Test Packet                               |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0101b       | Test FORCE_ENABLE                         |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 0110b-1111b | Reserved                                  |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 15:14       | /                                         | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 13          | R/W                                       | 0x1                                          | <p><b>Port Owner</b></p> <p>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.</p> <p>System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.</p> <p>Default Value = 1b.</p>                                                                                                                                                                                                                                                                                                                                                            |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 12          | /                                         | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 11:10       | R                                         | 0x0                                          | <p><b>Line Status</b></p> <p>These bits reflect the current logical levels of the D+ (bit11) and D- (bit10) signal lines. These bits are used for detection of low-speed USB devices prior to port reset and enable sequence. This read only field is valid only when the port enable bit is zero and the current connect status bit is set to a one.</p> <p>The encoding of the bits are:</p> <table border="1"> <thead> <tr> <th>Bit[11:10]</th><th>USB State</th><th>Interpretation</th></tr> </thead> <tbody> <tr><td>00b</td><td>SEO</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr><td>10b</td><td>J-state</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr><td>01b</td><td>K-state</td><td>Low-speed device, release ownership of port.</td></tr> <tr><td>11b</td><td>Undefined</td><td>Not Low-speed device, perform EHCI reset.</td></tr> </tbody> </table> <p>This value of this field is undefined if Port Power is zero.</p> | Bit[11:10] | USB State | Interpretation | 00b                                       | SEO   | Not Low-speed device, perform EHCI reset. | 10b   | J-state      | Not Low-speed device, perform EHCI reset. | 01b          | K-state | Low-speed device, release ownership of port. | 11b   | Undefined         | Not Low-speed device, perform EHCI reset. |          |
| Bit[11:10]  | USB State                                 | Interpretation                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 00b         | SEO                                       | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 10b         | J-state                                   | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 01b         | K-state                                   | Low-speed device, release ownership of port. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 11b         | Undefined                                 | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |
| 9           | /                                         | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |           |                |                                           |       |                                           |       |              |                                           |              |         |                                              |       |                   |                                           |          |

|                             |            |     | <b>Port Reset</b><br>1=Port is in Reset. 0=Port is not in Reset. Default value = 0.<br>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes.<br><b>Note: When software writes this bit to a one , it must also write a zero to the Port Enable bit.</b><br><br>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2 milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state with 2ms of software writing this bit to a zero.<br>The HC Halted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HC Halted bit is a one.<br>This field is zero if Port Power is zero. |                             |            |    |         |    |        |    |         |
|-----------------------------|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------|----|---------|----|--------|----|---------|
| 7                           | R/W        | 0x0 | <b>Suspend</b><br>Port Enabled Bit and Suspend bit of this register define the port states as follows:<br><table border="1"> <thead> <tr> <th>Bits[Port Enables, Suspend]</th> <th>Port State</th> </tr> </thead> <tbody> <tr> <td>0x</td> <td>Disable</td> </tr> <tr> <td>10</td> <td>Enable</td> </tr> <tr> <td>11</td> <td>Suspend</td> </tr> </tbody> </table> When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspend and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.<br>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:<br>① Software sets the Force Port Resume bit to a zero(from a one).<br>② Software sets the Port Reset bit to a one(from a zero).<br>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.<br>This field is zero if Port Power is zero.                                                                                                                                                                                                                                    | Bits[Port Enables, Suspend] | Port State | 0x | Disable | 10 | Enable | 11 | Suspend |
| Bits[Port Enables, Suspend] | Port State |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                             |            |    |         |    |        |    |         |
| 0x                          | Disable    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                             |            |    |         |    |        |    |         |
| 10                          | Enable     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                             |            |    |         |    |        |    |         |
| 11                          | Suspend    |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                             |            |    |         |    |        |    |         |

|   |      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |     | The default value in this field is '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6 | R/W  | 0x0 | <p><b>Force Port Resume</b><br/>           1 = Resume detected/driven on port. 0 = No resume (K-state) detected/driven on port. Default value = 0.<br/>           This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined.<br/>           Software sets this bit to a 1 drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit to a one, the host controller must not set the Port Change Detect bit.<br/>           Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero.<br/>           This field is zero if Port Power is zero.</p> |
| 5 | R/WC | 0x0 | <p><b>Over-current Change</b><br/>           Default = 0. This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4 | R    | 0x0 | <p><b>Over-current Active</b><br/>           0 = This port does not have an over-current condition. 1 = This port currently has an over-current condition. This bit will automatically transition from a one to a zero when the over current condition is removed.<br/>           The default value of this bit is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3 | R/WC | 0x0 | <p><b>Port Enable/Disable Change</b><br/>           Default = 0. 1 = Port enabled/disabled status has changed. 0 = No change.<br/>           For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification for the definition of a Port Error). Software clears this bit by writing a 1 to it.<br/>           This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2 | R/W  | 0x0 | <p><b>Port Enabled/Disabled</b><br/>           1=Enable, 0=Disable. Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.<br/>           Ports can be disabled by either a fault condition(disconnect event or other fault condition) or by host software. Note that the bit status does not change</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|   |      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |     | <p>until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events.</p> <p>When the port is disabled, downstream propagation of data is blocked on this port except for reset.</p> <p>The default value of this field is '0'.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                          |
| 1 | R/WC | 0x0 | <p><b>Connect Status Change</b></p> <p>1=Change in Current Connect Status, 0=No change, Default=0.</p> <p>Indicates a change has occurred in the port's Current Connect Status. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be "setting" an already-set bit. Software sets this bit to 0 by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p> |
| 0 | R    | 0x0 | <p><b>Current Connect Status</b></p> <p>Device is present on port when the value of this field is a one, and no device is present on port when the value of this field is a zero. This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change(Bit 1) to be set.</p> <p>This field is zero if Port Power zero.</p>                                                                                                                                                                                                                         |

**NOTE**

This register is only reset by hardware or in response to a host controller reset.

### 10.5.6. OHCI Register Description

#### 10.5.6.1. 0x0400 HcRevision Register(Default Value:0x0000\_0010)

| Offset: 0x0400 |            |    | Register Name: HcRevision |                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|----|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex               | Description                                                                                                                                                                                                                                                                                                             |
|                | HCD        | HC |                           |                                                                                                                                                                                                                                                                                                                         |
| 31:8           | /          | /  | /                         | /                                                                                                                                                                                                                                                                                                                       |
| 7:0            | R          | R  | 0x10                      | <p><b>Revision</b></p> <p>This read-only field contains the BCD representation of the version of the HCI specification that is implemented by this HC. For example, a value of 0x11 corresponds to version 1.1. All of the HC implementations that are compliant with this specification will have a value of 0x10.</p> |

#### 10.5.6.2. 0x0404 HcControl Register(Default Value:0x0000\_0000)

| Offset: 0x0404 |            |             | Register Name: HcRevision |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |

|       | HCD            | HC  |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
|-------|----------------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|-----------|-----|----------------|-----|------------|
| 31:11 | /              | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |          |     |           |     |                |     |            |
| 10    | R/W            | R   | 0x0 | <p><b>RemoteWakeupEnable</b><br/> This bit is used by HCD to enable or disable the remote wakeup feature upon the detection of upstream resume signaling. When this bit is set and the <b>ResumeDetected</b> bit in <b>HcInterruptStatus</b> is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |          |     |           |     |                |     |            |
| 9     | R/W            | R/W | 0x0 | <p><b>RemoteWakeupConnected</b><br/> This bit indicates whether HC supports remote wakeup signaling. If remote wakeup is supported and used by the system, it is the responsibility of system firmware to set this bit during POST. HC clear the bit upon a hardware reset but does not alter it upon a software reset. Remote wakeup signaling of the host system is host-bus-specific and is not described in this specification.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 8     | R/W            | R   | 0x0 | <p><b>InterruptRouting</b><br/> This bit determines the routing of interrupts generated by events registered in <b>HcInterruptStatus</b>. If clear, all interrupt are routed to the normal host bus interrupt mechanism. If set interrupts are routed to the System Management Interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
| 7:6   | R/W            | R/W | 0x0 | <p><b>HostControllerFunctionalState for USB</b></p> <table border="1"> <tr><td>00b</td><td>USBReset</td></tr> <tr><td>01b</td><td>USBResume</td></tr> <tr><td>10b</td><td>USBOperational</td></tr> <tr><td>11b</td><td>USBSuspend</td></tr> </table> <p>A transition to USBOperational from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the StartOfFrame field of <b>HcInterruptStatus</b>.</p> <p>This field may be changed by HC only when in the USBSUSPEND state. HC may move from the USBSUSPEND state to the USBRESUME state after detecting the resume signaling from a downstream port.</p> <p>HC enters USBSUSPEND after a software reset, whereas it enters USBRESET after a hardware reset. The latter also resets the Root Hub and asserts subsequent reset signaling to downstream ports.</p> | 00b | USBReset | 01b | USBResume | 10b | USBOperational | 11b | USBSuspend |
| 00b   | USBReset       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 01b   | USBResume      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 10b   | USBOperational |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 11b   | USBSuspend     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 5     | R/W            | R   | 0x0 | <p><b>BulkListEnable</b><br/> This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by HCD, processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <b>HcBulkCurrentED</b> is pointing to an ED to be removed, HCD must advance the pointer by updating <b>HcBulkCurrentED</b> before re-enabling processing of the list.</p>                                                                                                                                                                                                                                                                                                                                                                                                       |     |          |     |           |     |                |     |            |

| 4    | R/W                                     | R | 0x0 | <b>ControlListEnable</b><br>This bit is set to enable the processing of the Control list in the next Frame. If cleared by HCD, processing of the Control list does not occur after the next SOF. HC must check this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <i>HcControl/CurrentED</i> is pointing to an ED to be removed, HC must advance the pointer by updating <i>HcControl/CurrentED</i> before re-enabling processing of the list.                                                                                                                                                                                                                                                                                                                                |      |                                         |   |     |   |     |   |     |   |     |
|------|-----------------------------------------|---|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|---|-----|---|-----|---|-----|
| 3    | R/W                                     | R | 0x0 | <b>IsochronousEnable</b><br>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists.<br>Setting this bit is guaranteed to take effect in the next Frame (not the current Frame).                                                                                                                                                                                                                                                                                         |      |                                         |   |     |   |     |   |     |   |     |
| 2    | R/W                                     | R | 0x0 | <b>PeriodicListEnable</b><br>This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |                                         |   |     |   |     |   |     |   |     |
| 1:0  | R/W                                     | R | 0x0 | <b>ControlBulkServiceRatio</b><br>This specifies the service ratio between Control and Bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value. <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <th>CBSR</th> <th>No. of Control EDs Over Bulk EDs Served</th> </tr> <tr> <td>0</td> <td>1:1</td> </tr> <tr> <td>1</td> <td>2:1</td> </tr> <tr> <td>2</td> <td>3:1</td> </tr> <tr> <td>3</td> <td>4:1</td> </tr> </table> The default value is 0x0. | CBSR | No. of Control EDs Over Bulk EDs Served | 0 | 1:1 | 1 | 2:1 | 2 | 3:1 | 3 | 4:1 |
| CBSR | No. of Control EDs Over Bulk EDs Served |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                                         |   |     |   |     |   |     |   |     |
| 0    | 1:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                                         |   |     |   |     |   |     |   |     |
| 1    | 2:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                                         |   |     |   |     |   |     |   |     |
| 2    | 3:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                                         |   |     |   |     |   |     |   |     |
| 3    | 4:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |                                         |   |     |   |     |   |     |   |     |

#### 10.5.6.3. 0x0408 HcCommandStatus Register(Default Value:0x0000\_0000)

| Offset: 0x0408 |            |     | Register Name: HcCommandStatus |                                                                                                     |
|----------------|------------|-----|--------------------------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex                    | Description                                                                                         |
|                | HCD        | HC  |                                |                                                                                                     |
| 31:18          | /          | /   | 0x0                            | <b>Reserved</b>                                                                                     |
| 17:16          | R          | R/W | 0x0                            | <b>SchedulingOverrunCount</b><br>These bits are incremented on each scheduling overrun error. It is |

|      |     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     |     | initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if <b>SchedulingOverrun</b> in <i>HcInterruptStatus</i> has already been set. This is used by HCD to monitor any persistent scheduling problem.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:4 | /   | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3    | R/W | R/W | 0x0 | <p><b>OwnershipChangeRequest</b></p> <p>This bit is set by an OS HCD to request a change of control of the HC. When set HC will set the <b>OwnershipChange</b> field in <i>HcInterruptStatus</i>. After the changeover, this bit is cleared and remains so until the next request from OS HCD.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2    | R/W | R/W | 0x0 | <p><b>BulkListFilled</b></p> <p>This bit is used to indicate whether there are any TDs on the Bulk list. It is set by HCD whenever it adds a TD to an ED in the Bulk list.</p> <p>When HC begins to process the head of the Bulk list, it checks BLF. As long as <b>BulkListFilled</b> is 0, HC will not start processing the Bulk list. If <b>BulkListFilled</b> is 1, HC will start processing the Bulk list and will set BF to 0. If HC finds a TD on the list, then HC will set <b>BulkListFilled</b> to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set <b>BulkListFilled</b>, then <b>BulkListFilled</b> will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop.</p>                                                  |
| 1    | R/W | R/W | 0x0 | <p><b>ControlListFilled</b></p> <p>This bit is used to indicate whether there are any TDs on the Control list. It is set by HCD whenever it adds a TD to an ED in the Control list.</p> <p>When HC begins to process the head of the Control list, it checks CLF. As long as <b>ControlListFilled</b> is 0, HC will not start processing the Control list. If CF is 1, HC will start processing the Control list and will set <b>ControlListFilled</b> to 0. If HC finds a TD on the list, then HC will set <b>ControlListFilled</b> to 1 causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set <b>ControlListFilled</b>, then <b>ControlListFilled</b> will still be 0 when HC completes processing the Control list and Control list processing will stop.</p> |
| 0    | R/W | R/E | 0x0 | <p><b>HostControllerReset</b></p> <p>This bit is by HCD to initiate a software reset of HC. Regardless of the functional state of HC, it moves to the USBSuspend state in which most of the operational registers are reset except those stated otherwise; e.g, the InterruptRouting field of HcControl, and no Host bus accesses are allowed. This bit is cleared by HC upon the completion of the reset operation. The reset operation must be completed within 10 ms. This bit, when set, should not cause a reset to the Root Hub and no subsequent reset signaling should be asserted to its downstream ports.</p>                                                                                                                                                                                                        |

#### 10.5.6.4. 0x040C HcInterruptStatus Register(Default Value:0x0000\_0000)

|                |                                  |
|----------------|----------------------------------|
| Offset: 0x040C | Register Name: HcInterruptStatus |
|----------------|----------------------------------|

| Bit  | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                               |
|------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                           |
| 31:7 | /          | /   | /           | /                                                                                                                                                                                                                                                                                                         |
| 6    | R/W        | R/W | 0x0         | <b>RootHubStatusChange</b><br>This bit is set when the content of <i>HcRhStatus</i> or the content of any of <i>HcRhPortStatus[NumberofDownstreamPort]</i> has changed.                                                                                                                                   |
| 5    | R/W        | R/W | 0x0         | <b>FrameNumberOverflow</b><br>This bit is set when the MSb of <i>HcFmNumber</i> (bit 15) changes value, from 0 to 1 or from 1 to 0, and after <i>HccaFrameNumber</i> has been updated.                                                                                                                    |
| 4    | R/W        | R/W | 0x0         | <b>UnrecoverableError</b><br>This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.                                                          |
| 3    | R/W        | R/W | 0x0         | <b>ResumeDetected</b><br>This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the <i>USBRseume</i> state.                              |
| 2    | R/W        | R/W | 0x0         | <b>StartofFrame</b><br>This bit is set by HC at each start of frame and after the update of <i>HccaFrameNumber</i> . HC also generates a SOF token at the same time.                                                                                                                                      |
| 1    | R/W        | R/W | 0x0         | <b>WritebackDoneHead</b><br>This bit is set immediately after HC has written <i>HcDoneHead</i> to <i>HccaDoneHead</i> . Further updates of the <i>HccaDoneHead</i> will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of <i>HccaDoneHead</i> . |
| 0    | R/W        | R/W | 0x0         | <b>SchedulingOverrun</b><br>This bit is set when the USB schedule for the current Frame overruns and after the update of <i>HccaFrameNumber</i> . A scheduling overrun will also cause the <b>SchedulingOverrunCount</b> of <i>HcCommandStatus</i> to be incremented.                                     |

#### 10.5.6.5. 0x0410 HcInterruptEnable Register(Default Value:0x0000\_0000)

| Offset: 0x0410 |            |    |             | Register Name: HcInterruptEnable Register                                                                                                                                                                                                          |
|----------------|------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                        |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                    |
| 31             | R/W        | R  | 0x0         | <b>MasterInterruptEnable</b><br>A '0' written to this field is ignored by HC. A '1' written to this field enables interrupt generation due to events specified in the other bits of this register. This is used by HCD as Master Interrupt Enable. |
| 30:7           | /          | /  | /           | /                                                                                                                                                                                                                                                  |
| 6              | R/W        | R  | 0x0         | <b>RootHubStatusChange Interrupt Enable</b>                                                                                                                                                                                                        |

|   |                                                            |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
|---|------------------------------------------------------------|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|------------------------------------------------------------|--|
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Root Hub Status Change;</td></tr> </table> | 0 | Ignore; | 1 | Enable interrupt generation due to Root Hub Status Change; |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Root Hub Status Change; |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 5 | R/W                                                        | R | 0x0 | <b>FrameNumberOverflow Interrupt Enable</b>                                                                                                            |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Frame Number Over Flow;</td></tr> </table> | 0 | Ignore; | 1 | Enable interrupt generation due to Frame Number Over Flow; |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Frame Number Over Flow; |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 4 | R/W                                                        | R | 0x0 | <b>UnrecoverableError Interrupt Enable</b>                                                                                                             |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Unrecoverable Error;</td></tr> </table>    | 0 | Ignore; | 1 | Enable interrupt generation due to Unrecoverable Error;    |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Unrecoverable Error;    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 3 | R/W                                                        | R | 0x0 | <b>ResumeDetected Interrupt Enable</b>                                                                                                                 |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Resume Detected;</td></tr> </table>        | 0 | Ignore; | 1 | Enable interrupt generation due to Resume Detected;        |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Resume Detected;        |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 2 | R/W                                                        | R | 0x0 | <b>StartofFrame Interrupt Enable</b>                                                                                                                   |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Start of Flame;</td></tr> </table>         | 0 | Ignore; | 1 | Enable interrupt generation due to Start of Flame;         |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Start of Flame;         |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | R/W                                                        | R | 0x0 | <b>WritebackDoneHead Interrupt Enable</b>                                                                                                              |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Write back Done Head;</td></tr> </table>   | 0 | Ignore; | 1 | Enable interrupt generation due to Write back Done Head;   |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Write back Done Head;   |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 0 | R/W                                                        | R | 0x0 | <b>SchedulingOverrun Interrupt Enable</b>                                                                                                              |   |         |   |                                                            |  |
|   |                                                            |   |     | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Enable interrupt generation due to Scheduling Overrun;</td></tr> </table>     | 0 | Ignore; | 1 | Enable interrupt generation due to Scheduling Overrun;     |  |
| 0 | Ignore;                                                    |   |     |                                                                                                                                                        |   |         |   |                                                            |  |
| 1 | Enable interrupt generation due to Scheduling Overrun;     |   |     |                                                                                                                                                        |   |         |   |                                                            |  |

#### 10.5.6.6. 0x0414 HcInterruptDisable Register(Default Value:0x0000\_0000)

| Offset: 0x0414 |                                                             |    |             | Register Name: HcInterruptDisable Register                                                                                                                                                                                                             |   |         |   |                                                             |
|----------------|-------------------------------------------------------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|-------------------------------------------------------------|
| Bit            | Read/Write                                                  |    | Default/Hex | Description                                                                                                                                                                                                                                            |   |         |   |                                                             |
|                | HCD                                                         | HC |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 31             | R/W                                                         | R  | 0x0         | <b>MasterInterruptEnable</b><br>A written '0' to this field is ignored by HC. A '1' written to this field disables interrupt generation due events specified in the other bits of this register. This field is set after a hardware or software reset. |   |         |   |                                                             |
| 30:7           | /                                                           | /  | /           | /                                                                                                                                                                                                                                                      |   |         |   |                                                             |
| 6              | R/W                                                         | R  | 0x0         | <b>RootHubStatusChange Interrupt Disable</b>                                                                                                                                                                                                           |   |         |   |                                                             |
|                |                                                             |    |             | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Root Hub Status Change;</td></tr> </table>                                                                                                | 0 | Ignore; | 1 | Disable interrupt generation due to Root Hub Status Change; |
| 0              | Ignore;                                                     |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1              | Disable interrupt generation due to Root Hub Status Change; |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 5              | R/W                                                         | R  | 0x0         | <b>FrameNumberOverflow Interrupt Disable</b>                                                                                                                                                                                                           |   |         |   |                                                             |
|                |                                                             |    |             | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Frame Number Over Flow;</td></tr> </table>                                                                                                | 0 | Ignore; | 1 | Disable interrupt generation due to Frame Number Over Flow; |
| 0              | Ignore;                                                     |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1              | Disable interrupt generation due to Frame Number Over Flow; |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 4              | R/W                                                         | R  | 0x0         | <b>UnrecoverableError Interrupt Disable</b>                                                                                                                                                                                                            |   |         |   |                                                             |
|                |                                                             |    |             | <table border="1"> <tr><td>0</td><td>Ignore;</td></tr> <tr><td>1</td><td>Disable interrupt generation due to Unrecoverable Error;</td></tr> </table>                                                                                                   | 0 | Ignore; | 1 | Disable interrupt generation due to Unrecoverable Error;    |
| 0              | Ignore;                                                     |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 1              | Disable interrupt generation due to Unrecoverable Error;    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                             |
| 3              | R/W                                                         | R  | 0x0         | <b>ResumeDetected Interrupt Disable</b>                                                                                                                                                                                                                |   |         |   |                                                             |

|   |     |   |     |                                            |                                                           |  |
|---|-----|---|-----|--------------------------------------------|-----------------------------------------------------------|--|
|   |     |   |     | 0                                          | Ignore;                                                   |  |
|   |     |   |     | 1                                          | Disable interrupt generation due to Resume Detected;      |  |
| 2 | R/W | R | 0x0 | <b>StartofFrame Interrupt Disable</b>      |                                                           |  |
|   |     |   |     | 0                                          | Ignore;                                                   |  |
|   |     |   |     | 1                                          | Disable interrupt generation due to Start of Flame;       |  |
| 1 | R/W | R | 0x0 | <b>WritebackDoneHead Interrupt Disable</b> |                                                           |  |
|   |     |   |     | 0                                          | Ignore;                                                   |  |
|   |     |   |     | 1                                          | Disable interrupt generation due to Write back Done Head; |  |
| 0 | R/w | R | 0x0 | <b>SchedulingOverrun Interrupt Disable</b> |                                                           |  |
|   |     |   |     | 0                                          | Ignore;                                                   |  |
|   |     |   |     | 1                                          | Disable interrupt generation due to Scheduling Overrun;   |  |

#### 10.5.6.7. 0x0418 HcHCCA Register(Default Value:0x0000\_0000)

| Offset: 0x0418 |            |    |             | Register Name: HcHCCA                                                                                                                                                                                                      |  |
|----------------|------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                |  |
|                | HCD        | HC |             |                                                                                                                                                                                                                            |  |
| 31:8           | R/W        | R  | 0x0         | <b>HCCA[31:8]</b>                                                                                                                                                                                                          |  |
|                |            |    |             | This is the base address of the Host Controller Communication Area. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver. |  |
| 7:0            | R          | R  | 0x0         | <b>HCCA[7:0]</b>                                                                                                                                                                                                           |  |
|                |            |    |             | The alignment restriction in HcHCCA register is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes, therefore, bits 0 through 7 must always return 0 when read.        |  |

#### 10.5.6.8. 0x041C HcPeriodCurrentED Register(Default Value:0x0000\_0000)

| Offset: 0x041C |            |     |             | Register Name: HcPeriodCurrentED(PCED)                                                                                                                                                                                                                                                                        |  |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |  |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                               |  |
| 31:4           | R          | R/W | 0x0         | <b>PCED[31:4]</b>                                                                                                                                                                                                                                                                                             |  |
|                |            |     |             | This is used by HC to point to the head of one of the Periodic list which will be processed in the current Frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading. |  |
| 3:0            | R          | R   | 0x0         | <b>PCED[3:0]</b>                                                                                                                                                                                                                                                                                              |  |
|                |            |     |             | Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                           |  |

#### 10.5.6.9. 0x0420 HcControlHeadED Register(Default Value:0x0000\_0000)

| Offset: 0x0420 |            |    |             | Register Name: HcControlHeadED[CHED]                                                                                                                                                                                                                                           |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                    |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                |
| 31:4           | R/W        | R  | 0x0         | <b>EHCD[31:4]</b><br>The HcControlHeadED register contains the physical address of the first Endpoint Descriptor of the Control list. HC traverse the Control list starting with the HcControlHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0            | R          | R  | 0x0         | <b>EHCD[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                        |

#### 10.5.6.10. 0x0424 HcControlCurrentED Register

| Offset: 0x0424 |            |     |             | Register Name: HcControlCurrentED[CCED]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:4           | R/W        | R/W | 0x0         | <b>CCED[31:4]</b><br>The pointer is advanced to the next ED after serving the present one. HC will continue processing the list from where it left off in the last Frame. When it reaches the end of the Control list, HC checks the ControlListFilled of in HcCommandStatus. If set, it copies the content of HcControlHeadED to HcControlCurrentED and clears the bit. If not set, it does nothing.<br>HCD is allowed to modify this register only when the ControlListEnable of HcControl is cleared. When set, HCD only reads the instantaneous value of this register. Initially, this is set to zero to indicate the end of the Control list. |
| 3:0            | R          | R   | 0x0         | <b>CCED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 10.5.6.11. 0x0428 HcBulkHeadED Register(Default Value:0x0000\_0000)

| Offset: 0x0428 |            |    |             | Register Name: HcBulkHeadED[BHED]                                                         |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                               |
|                | HCD        | HC |             |                                                                                           |
| 31:4           | R/W        | R  | 0x0         | <b>BHED[31:4]</b><br>The HcBulkHeadED register contains the physical address of the first |

|     |   |   |     |                                                                                                                                                                                                                                    |
|-----|---|---|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |   |   |     | Endpoint Descriptor of the Bulk list. HC traverses the Bulk list starting with the HcBulkHeadED pointer. The content is loaded from HCCA during the initialization of HC.                                                          |
| 3:0 | R | R | 0x0 | <p><b>BHED[3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p> |

#### 10.5.6.12. 0x042C HcBulkCurrentED Register(Default Value:0x0000\_0000)

| Offset: 0x042C |            |     |             | Register Name: HcBulkCurrentED [BCED]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:4           | R/W        | R/W | 0x0         | <p><b>BulkCurrentED[31:4]</b></p> <p>This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last Frame. When it reaches the end of the Bulk list, HC checks the <b>ControlListFilled</b> of HcControl. If set, it copies the content of <i>HcBulkHeadED</i> to <i>HcBulkCurrentED</i> and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the <b>BulkListEnable</b> of <i>HcControl</i> is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to zero to indicate the end of the Bulk list.</p> |
| 3:0            | R          | R   | 0x0         | <p><b>BulkCurrentED [3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 10.5.6.13. 0x0430 HcDoneHead Register(Default Value:0x0000\_0000)

| Offset: 0x0430 |            |     |             | Register Name: HcDoneHead                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                              |
| 31:4           | R          | R/W | 0x0         | <p><b>HcDoneHead[31:4]</b></p> <p>When a TD is completed, HC writes the content of <i>HcDoneHead</i> to the NextTD field of the TD. HC then overwrites the content of <i>HcDoneHead</i> with the address of this TD. This is set to zero whenever HC writes the content of this register to HCCA. It also sets the <b>WritebackDoneHead</b> of <i>HcInterruptStatus</i>.</p> |
| 3:0            | R          | R   | 0x0         | <p><b>HcDoneHead[3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                     |

#### 10.5.6.14. 0x0434 HcFmInterval Register(Default Value:0x0000\_2EDF)

| Offset: 0x0434 |            |    |             | Register Name: HcFmInterval Register                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/W        | R  | 0x0         | <b>FrameIntervalToggler</b><br>HCD toggles this bit whenever it loads a new value to <b>FrameInterval</b> .                                                                                                                                                                                                                                                                                                                                     |
| 30:16          | R/W        | R  | 0x0         | <b>FSLargestDataPacket</b><br>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD.                                                                 |
| 15:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13:0           | R/W        | R  | 0x2edf      | <b>FrameInterval</b><br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the <b>HostControllerReset</b> field of <i>HcCommandStatus</i> as this will cause the HC to reset this field to its nominal value. HCD may choose to restore the stored value upon the completion of the Reset sequence. |

#### 10.5.6.15. 0x0438 HcFmRemaining Register(Default Value:0x0000\_0000)

| Offset: 0x0438 |            |     |             | Register Name: HcFmRemaining                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                         |
| 31             | R          | R/W | 0x0         | <b>FrameRemaining Toggle</b><br>This bit is loaded from the <b>FrameIntervalToggle</b> field of <i>HcFmInterval</i> whenever <b>FrameRemaining</b> reaches 0. This bit is used by HCD for the synchronization between <b>FrameInterval</b> and <b>FrameRemaining</b> .                                                                                                  |
| 30:14          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 13:0           | R          | RW  | 0x0         | <b>FrameRemaining</b><br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the FrameInterval value specified in <i>HcFmInterval</i> at the next bit time boundary. When entering the USBOPERATIONAL state, HC re-loads the content with the FrameInterval of <i>HcFmInterval</i> and uses the updated value from the next SOF. |

#### 10.5.6.16. 0x043C HcFmNumber Register(Default Value:0x0000\_0000)

| Offset: 0x043C |            |     |             | Register Name: HcFmNumber                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:16          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:0           | R          | R/W | 0x0         | <p><b>FrameNumber</b></p> <p>This is incremented when <i>HcFmRemaining</i> is re-loaded. It will be rolled over to 0x0 after 0xffff. When entering the USBOPERATIONAL state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the <b>FrameNumber</b> at each frame boundary and sent a SOF but before HC reads the first ED in that Frame. After writing to HCCA, HC will set the <b>StartofFrame</b> in <i>HcInterruptStatus</i>.</p> |

#### 10.5.6.17. 0x0440 HcPeriodicStart Register(Default Value:0x0000\_0000)

| Offset: 0x0440 |            |    |             | Register Name: HcPeriodicStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:0           | R/W        | R  | 0x0         | <p><b>PeriodicStart</b></p> <p>After a hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from <i>HcFmInterval</i>. A typical value will be 0x2A3F (0x3e67??). When <i>HcFmRemaining</i> reaches the value specified, processing of the periodic lists will have priority over Control/Bulk processing. HC will therefore start processing the Interrupt list after completing the current Control or Bulk transaction that is in progress.</p> |

#### 10.5.6.18. 0x0444 HcLSThreshold Register(Default Value:0x0000\_0628)

| Offset: 0x0444 |            |    |             | Register Name: HcLSThreshold                                                                                                                                                                                                                                                                                                               |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                            |
| 31:12          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                          |
| 11:0           | R/W        | R  | 0x0628      | <p><b>LSThreshold</b></p> <p>This field contains a value which is compared to the <b>FrameRemaining</b> field prior to initiating a Low Speed transaction. The transaction is started only if <b>FrameRemaining</b> <sup>3</sup> this field. The value is calculated by HCD with the consideration of transmission and setup overhead.</p> |

## 10.5.6.19. 0x0448 HcRhDescriptorA Register(Default Value:0x0200\_1201)

| Offset: 0x0448 |                                                                                                                                                                                                                                                                                                                                                                                          |    |             | Register Name: HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                                                                                                                                                                                                                               |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|                | HCD                                                                                                                                                                                                                                                                                                                                                                                      | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:24          | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x2         | <b>PowerOnToPowerGoodTime[POTPGT]</b><br>This byte specifies the duration HCD has to wait before accessing a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 23:13          | /                                                                                                                                                                                                                                                                                                                                                                                        | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 12             | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x1         | <b>NoOverCurrentProtection</b><br>This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the <b>OverCurrentProtectionMode</b> field specifies global or per-port reporting. <table border="1" style="margin-left: 20px;"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>No overcurrent protection supported.</td></tr> </table>                                                                                                                                                                                                                                                                                                               | 0 | Over-current status is reported collectively for all downstream ports. | 1 | No overcurrent protection supported.                                                                                                                                                                                                                                                                                                                                                     |
| 0              | Over-current status is reported collectively for all downstream ports.                                                                                                                                                                                                                                                                                                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | No overcurrent protection supported.                                                                                                                                                                                                                                                                                                                                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 11             | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x0         | <b>OverCurrentProtectionMode</b><br>This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as <b>PowerSwitchingMode</b> . This field is valid only if the <b>NoOverCurrentProtection</b> field is cleared. <table border="1" style="margin-left: 20px;"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>Over-current status is reported on per-port basis.</td></tr> </table>                                                                                                                                                                                                                                        | 0 | Over-current status is reported collectively for all downstream ports. | 1 | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |
| 0              | Over-current status is reported collectively for all downstream ports.                                                                                                                                                                                                                                                                                                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 10             | R                                                                                                                                                                                                                                                                                                                                                                                        | R  | 0x0         | <b>Device Type</b><br>This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 9              | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x1         | <b>PowerSwitchingMode</b><br>This bit is used to specify how the power switching of the Root Hub ports is controlled. It is implementation-specific. This field is only valid if the <b>NoPowerSwitching</b> field is cleared. <table border="1" style="margin-left: 20px;"> <tr> <td>0</td><td>All ports are powered at the same time.</td></tr> <tr> <td>1</td><td>Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (<b>Set/ClearPortPower</b>). If the port mask is cleared, then the port is controlled only by the global power switch (<b>Set/ClearGlobalPower</b>).</td></tr> </table> | 0 | All ports are powered at the same time.                                | 1 | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |
| 0              | All ports are powered at the same time.                                                                                                                                                                                                                                                                                                                                                  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |

|          |                                                        |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                           |          |                                                        |
|----------|--------------------------------------------------------|---|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------|----------|--------------------------------------------------------|
| 8        | R/W                                                    | R | 0x0  | <p><b>NoPowerSwitching</b></p> <p>These bits are used to specify whether power switching is supported or ports are always powered. It is implementation-specific. When this bit is cleared, the <b>PowerSwitchingMode</b> specifies global or per-port switching.</p> <table border="1"> <tr> <td><b>0</b></td><td>Ports are power switched.</td></tr> <tr> <td><b>1</b></td><td>Ports are always powered on when the HC is powered on.</td></tr> </table> | <b>0</b> | Ports are power switched. | <b>1</b> | Ports are always powered on when the HC is powered on. |
| <b>0</b> | Ports are power switched.                              |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                           |          |                                                        |
| <b>1</b> | Ports are always powered on when the HC is powered on. |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |                           |          |                                                        |
| 7:0      | R                                                      | R | 0x01 | <p><b>NumberDownstreamPorts</b></p> <p>These bits specify the number of downstream ports supported by the Root Hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported.</p>                                                                                                                                                                                                                            |          |                           |          |                                                        |

#### 10.5.6.20. 0x044C HcRhDescriptorB Register (Default Value:0x0000\_0000)

| Offset: 0x044C |                                |    |             | Register Name: HcRhDescriptorB Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |          |      |                               |      |                               |     |  |       |                                |
|----------------|--------------------------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
| Bit            | Read/Write                     |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |          |      |                               |      |                               |     |  |       |                                |
|                | HCD                            | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| 31:16          | R/W                            | R  | 0x0         | <p><b>PortPowerControlMask</b></p> <p>Each bit indicates if a port is affected by a global power control command when <b>PowerSwitchingMode</b> is set. When set, the port's power state is only affected by per-port power control (<b>Set/ClearPortPower</b>). When cleared, the port is controlled by the global power switch (<b>Set/ClearGlobalPower</b>). If the device is configured to global switching mode (<b>PowerSwitchingMode</b> = 0 ), this field is not valid.</p> <table border="1"> <tr> <td>Bit0</td> <td>Reserved</td> </tr> <tr> <td>Bit1</td> <td>Ganged-power mask on Port #1.</td> </tr> <tr> <td>Bit2</td> <td>Ganged-power mask on Port #2.</td> </tr> <tr> <td>...</td> <td></td> </tr> <tr> <td>Bit15</td> <td>Ganged-power mask on Port #15.</td> </tr> </table> | Bit0 | Reserved | Bit1 | Ganged-power mask on Port #1. | Bit2 | Ganged-power mask on Port #2. | ... |  | Bit15 | Ganged-power mask on Port #15. |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Ganged-power mask on Port #1.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Ganged-power mask on Port #2.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Ganged-power mask on Port #15. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| 15:0           | R/W                            | R  | 0x0         | <p><b>DeviceRemovable</b></p> <p>Each bit is dedicated to a port of the Root Hub. When cleared, the attached device is removable. When set, the attached device is not removable.</p> <table border="1"> <tr> <td>Bit0</td> <td>Reserved</td> </tr> <tr> <td>Bit1</td> <td>Device attached to Port #1.</td> </tr> <tr> <td>Bit2</td> <td>Device attached to Port #2.</td> </tr> <tr> <td>...</td> <td></td> </tr> <tr> <td>Bit15</td> <td>Device attached to Port #15.</td> </tr> </table>                                                                                                                                                                                                                                                                                                     | Bit0 | Reserved | Bit1 | Device attached to Port #1.   | Bit2 | Device attached to Port #2.   | ... |  | Bit15 | Device attached to Port #15.   |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Device attached to Port #1.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Device attached to Port #2.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Device attached to Port #15.   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |          |      |                               |      |                               |     |  |       |                                |

#### 10.5.6.21. 0x0450 HcRhStatus Register (Default Value:0x0000\_0000)

| Offset: 0x0450 | Register Name: HcRhStatus Register |
|----------------|------------------------------------|
|----------------|------------------------------------|

| Bit   | Read/Write                                               |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                          |   |                                                      |
|-------|----------------------------------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------|---|------------------------------------------------------|
|       | HCD                                                      | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                                          |   |                                                      |
| 31    | W                                                        | R   | 0x0         | <p><b>(write)ClearRemoteWakeupsEnable</b><br/>Write a '1' clears <b>DeviceRemoteWakeupsEnable</b>. Writing a '0' has no effect.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                          |   |                                                      |
| 30:18 | /                                                        | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                                                          |   |                                                      |
| 17    | R/W                                                      | R   | 0x0         | <p><b>OverCurrentIndicatorChang</b><br/>This bit is set by hardware when a change has occurred to the <b>OverCurrentIndicator</b> field of this register. The HCD clears this bit by writing a '1'. Writing a '0' has no effect.</p>                                                                                                                                                                                                                                                                                                                                                                                |   |                                                          |   |                                                      |
| 16    | R/W                                                      | R   | 0x0         | <p><b>(read)LocalPowerStartusChange</b><br/>The Root Hub does not support the local power status features, thus, this bit is always read as '0'.<br/><b>(write)SetGlobalPower</b><br/>In global power mode (<b>PowerSwitchingMode</b>=0), This bit is written to '1' to turn on power to all ports (clear <b>PortPowerStatus</b>). In per-port power mode, it sets <b>PortPowerStatus</b> only on ports whose <b>PortPowerControlMask</b> bit is not set. Writing a '0' has no effect.</p>                                                                                                                          |   |                                                          |   |                                                      |
| 15    | R/W                                                      | R   | 0x0         | <p><b>(read)DeviceRemoteWakeupsEnable</b><br/>This bit enables a <b>ConnectStatusChange</b> bit as a resume event, causing a USBSUSPEND to USBRESUME state transition and setting the <b>ResumeDetected</b> interrupt.</p> <table border="1"> <tr> <td>0</td><td><b>ConnectStatusChange</b> is not a remote wakeup event.</td></tr> <tr> <td>1</td><td><b>ConnectStatusChange</b> is a remote wakeup event.</td></tr> </table> <p><b>(write)SetRemoteWakeupsEnable</b><br/>Writing a '1' sets <b>DeviceRemoveWakeupsEnable</b>. Writing a '0' has no effect.</p>                                                    | 0 | <b>ConnectStatusChange</b> is not a remote wakeup event. | 1 | <b>ConnectStatusChange</b> is a remote wakeup event. |
| 0     | <b>ConnectStatusChange</b> is not a remote wakeup event. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                                          |   |                                                      |
| 1     | <b>ConnectStatusChange</b> is a remote wakeup event.     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                                          |   |                                                      |
| 14:2  | /                                                        | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                                                          |   |                                                      |
| 1     | R                                                        | R/W | 0x0         | <p><b>OverCurrentIndicator</b><br/>This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal.<br/>If per-port overcurrent protection is implemented this bit is always '0'</p>                                                                                                                                                                                                                                                                                                                     |   |                                                          |   |                                                      |
| 0     | R/W                                                      | R   | 0x0         | <p><b>(Read)LocalPowerStatus</b><br/>When read, this bit returns the LocalPowerStatus of the Root Hub. The Root Hub does not support the local power status feature; thus, this bit is always read as '0'.<br/><b>(Write)ClearGlobalPower</b><br/>When write, this bit is operated as the ClearGlobalPower. In global power mode (<b>PowerSwitchingMode</b>=0), This bit is written to '1' to turn off power to all ports (clear <b>PortPowerStatus</b>). In per-port power mode, it clears <b>PortPowerStatus</b> only on ports whose <b>PortPowerControlMask</b> bit is not set. Writing a '0' has no effect.</p> |   |                                                          |   |                                                      |

## 10.5.6.22. 0x0454 HcRhPortStatus Register(Default Value:0x0000\_0100)

| Offset: 0x0454 |                                              |     |             | Register Name: HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
|----------------|----------------------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------|---|---------------------------------------------|
| Bit            | Read/Write                                   |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                              |   |                                             |
|                | HCD                                          | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 31:21          | /                                            | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                              |   |                                             |
| 20             | R/W                                          | R/W | 0x0         | <p><b>PortResetStatusChange</b><br/> This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>port reset is not complete</td></tr> <tr> <td>1</td><td>port reset is complete</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 | port reset is not complete                   | 1 | port reset is complete                      |
| 0              | port reset is not complete                   |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 1              | port reset is complete                       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 19             | R/W                                          | R/W | 0x0         | <p><b>PortOverCurrentIndicatorChange</b><br/> This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when Root Hub changes the <b>PortOverCurrentIndicator</b> bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortOverCurrentIndicator</b></td></tr> <tr> <td>1</td><td><b>PortOverCurrentIndicator</b> has changed</td></tr> </table>                                                                                                                                                                                                                                                                                                               | 0 | no change in <b>PortOverCurrentIndicator</b> | 1 | <b>PortOverCurrentIndicator</b> has changed |
| 0              | no change in <b>PortOverCurrentIndicator</b> |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 1              | <b>PortOverCurrentIndicator</b> has changed  |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 18             | R/W                                          | R/W | 0x0         | <p><b>PortSuspendStatusChange</b><br/> This bit is set when the full resume sequence has been completed. This sequence includes the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. This bit is also cleared when <b>ResetStatusChange</b> is set.</p> <table border="1"> <tr> <td>0</td><td>resume is not completed</td></tr> <tr> <td>1</td><td>resume completed</td></tr> </table>                                                                                                                                                                                                                                                                                                               | 0 | resume is not completed                      | 1 | resume completed                            |
| 0              | resume is not completed                      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 1              | resume completed                             |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 17             | R/W                                          | R/W | 0x0         | <p><b>PortEnableStatusChange</b><br/> This bit is set when hardware events cause the <b>PortEnableStatus</b> bit to be cleared. Changes from HCD writes do not set this bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                    | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0              | no change in <b>PortEnableStatus</b>         |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 1              | change in <b>PortEnableStatus</b>            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 16             | R/W                                          | R/W | 0x0         | <p><b>ConnectStatusChange</b><br/> This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared when a <b>SetPortReset</b>, <b>SetPortEnable</b>, or <b>SetPortSuspend</b> write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table> <p><b>Note:</b> If the <b>DeviceRemovable[NDP]</b> bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</p> | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0              | no change in <b>PortEnableStatus</b>         |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 1              | change in <b>PortEnableStatus</b>            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 15:10          | /                                            | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                              |   |                                             |

|     |                                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
|-----|---------------------------------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|-----------------------------|
|     |                                 |     |     | (read) <b>LowSpeedDeviceAttached</b><br>This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When clear, a Full Speed device is attached to this port. This field is valid only when the <b>CurrentConnectStatus</b> is set.<br><table border="1"><tr><td>0</td><td>full speed device attached</td></tr><tr><td>1</td><td>low speed device attached</td></tr></table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 | full speed device attached      | 1 | low speed device attached   |
| 0   | full speed device attached      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
| 1   | low speed device attached       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
| 9   | R/W                             | R/W | 0x0 | (write) <b>ClearPortPower</b><br>The HCD clears the <b>PortPowerStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                                 |   |                             |
| 8   | R/W                             | R/W | 0x1 | (read) <b>PortPowerStatus</b><br>This bit reflects the port's power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing <b>SetPortPower</b> or <b>SetGlobalPower</b> . HCD clears this bit by writing <b>ClearPortPower</b> or <b>ClearGlobalPower</b> . Which power control switches are enabled is determined by <b>PowerSwitchingMode</b> and <b>PortPortControlMask[NumberDownstreamPort]</b> . In global switching mode( <b>PowerSwitchingMode</b> =0), only <b>Set/ClearGlobalPower</b> controls this bit. In per-port power switching ( <b>PowerSwitchingMode</b> =1), if the <b>PortPowerControlMask[NDP]</b> bit for the port is set, only <b>Set/ClearPortPower</b> commands are enabled. If the mask is not set, only <b>Set/ClearGlobalPower</b> commands are enabled. When port power is disabled, <b>CurrentConnectStatus</b> , <b>PortEnableStatus</b> , <b>PortSuspendStatus</b> , and <b>PortResetStatus</b> should be reset.<br><table border="1"><tr><td>0</td><td>port power is off</td></tr><tr><td>1</td><td>port power is on</td></tr></table><br>(write) <b>SetPortPower</b><br>The HCD writes a '1' to set the <b>PortPowerStatus</b> bit. Writing a '0' has no effect.<br><br><b>Note: This bit is always reads '1b' if power switching is not supported.</b> | 0 | port power is off               | 1 | port power is on            |
| 0   | port power is off               |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
| 1   | port power is on                |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
| 7:5 | /                               | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                 |   |                             |
| 4   | R/W                             | R/W | 0x0 | (read) <b>PortResetStatus</b><br>When this bit is set by a write to <b>SetPortReset</b> , port reset signaling is asserted. When reset is completed, this bit is cleared when <b>PortResetStatusChange</b> is set. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared.<br><table border="1"><tr><td>0</td><td>port reset signal is not active</td></tr><tr><td>1</td><td>port reset signal is active</td></tr></table><br>(write) <b>SetPortReset</b><br>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 | port reset signal is not active | 1 | port reset signal is active |
| 0   | port reset signal is not active |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |
| 1   | port reset signal is active     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |

|   |                                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
|---|---------------------------------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------|---|---------------------------------|
|   |                                 |     |     | '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortResetStatus</b> , but instead sets <b>ConnectStatusChange</b> . This informs the driver that it attempted to reset a disconnected port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                           |   |                                 |
| 3 | R/W                             | R/W | 0x0 | <p>(read)<b>PortOverCurrentIndicator</b></p> <p>This bit is only valid when the Root Hub is configured in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent condition exists on this port. This bit always reflects the overcurrent input signal.</p> <table border="1"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table> <p>(write)<b>ClearSuspendStatus</b></p> <p>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if <b>PortSuspendStatus</b> is set.</p>                                                                                                                                                                                                                                                                     | 0 | no overcurrent condition. | 1 | overcurrent condition detected. |
| 0 | no overcurrent condition.       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
| 1 | overcurrent condition detected. |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
| 2 | R/W                             | R/W | 0x0 | <p>(read)<b>PortSuspendStatus</b></p> <p>This bit indicates the port is suspended or in the resume sequence. It is set by a <b>SetSuspendState</b> write and cleared when <b>PortSuspendStatusChange</b> is set at the end of the resume interval. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared. This bit is also cleared when <b>PortResetStatusChange</b> is set at the end of the port reset or when the HC is placed in the USBRESUME state. If an upstream resume is in progress, it should propagate to the HC.</p> <table border="1"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table> <p>(write)<b>SetPortSuspend</b></p> <p>The HCD sets the <b>PortSuspendStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortSuspendStatus</b>; instead it sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to suspend a disconnected port.</p> | 0 | port is not suspended     | 1 | port is suspended               |
| 0 | port is not suspended           |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
| 1 | port is suspended               |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
| 1 | R/W                             | R/W | 0x0 | <p>(read)<b>PortEnableStatus</b></p> <p>This bit indicates whether the port is enabled or disabled. The Root Hub may clear this bit when an overcurrent condition, disconnect event, switched-off power, or operational bus error such as babble is detected. This change also causes <b>PortEnabledStatusChange</b> to be set. HCD sets this bit by writing <b>SetPortEnable</b> and clears it by writing <b>ClearPortEnable</b>. This bit cannot be set when <b>CurrentConnectStatus</b> is cleared. This bit is also set, if not already, at the completion of a port reset when <b>ResetStatusChange</b> is set or port suspend when <b>SuspendStatusChange</b> is set.</p> <table border="1"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table>                                                                                                                                                                                                                                             | 0 | port is disabled          | 1 | port is enabled                 |
| 0 | port is disabled                |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |
| 1 | port is enabled                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                           |   |                                 |

|   |                     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                     |   |                  |
|---|---------------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---|------------------|
|   |                     |     |     | (write) <b>SetPortEnable</b><br>The HCD sets <b>PortEnableStatus</b> by writing a '1'. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortEnableStatus</b> , but instead sets <b>ConnectStatusChange</b> . This informs the driver that it attempted to enable a disconnected Port.                                                                                                                                                                                                                                                        |   |                     |   |                  |
| 0 | R/W                 | R/W | 0x0 | (read) <b>CurrentConnectStatus</b><br>This bit reflects the current state of the downstream port.<br><table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table><br>(b) (write) <b>ClearPortEnable</b><br>The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' has no effect. The CurrentConnectStatus is not affected by any write.<br><b>Note:</b> This bit is always read '1' when the attached device is nonremovable(DeviceRemovable[NumberDownstreamPort]). | 0 | No device connected | 1 | Device connected |
| 0 | No device connected |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                     |   |                  |
| 1 | Device connected    |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                     |   |                  |

### 10.5.7. HCI Controller and PHY Interface Description

#### 10.5.7.1. 0x0800 HCI Interface Register(Default Value:0x1000\_0000)

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31             | R/W        | 0x0         | USB Standby Clock Select<br>0: Normal mode usb clock as usual<br>1: Standby mode usb clock switch to RC 16M clock                               |
| 30:29          | /          | /           | /.                                                                                                                                              |
| 28             | R          | 0x1         | DMA Transfer Status Enable<br>0: Disable<br>1: Enable                                                                                           |
| 27:26          | /          | /           | /                                                                                                                                               |
| 25             | R/W        | 0x0         | OHCI count select<br>1: Simulation mode, the counters will be much shorter than real time<br>0: Normal mode, the counters will count full time  |
| 24             | R/W        | 0x0         | Simulation mode<br>1: Set PHY in a non-driving mode so the EHCI can detect device connection, this is used only for simulation<br>0: No effect  |
| 23:21          | /          | /           | /                                                                                                                                               |
| 20             | R/W        | 0x0         | EHCI HS force<br>Set 1 to this field force the ehci enter the high speed mode during bus reset.<br>This field only valid when the bit 1 is set. |
| 19             | /          | /           | /                                                                                                                                               |
| 18             | R/W        | 0x0         | 1: within 2us of the resume-K to SEO transition                                                                                                 |

|       |     |     |                                                                                                                                                                                                                                                    |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: random time value of the resume-K to SEO transition                                                                                                                                                                                             |
| 17:13 | /   | /   | /                                                                                                                                                                                                                                                  |
| 12    | R/W | 0x0 | PP2VBUS<br>1: ULPI wrapper interface will automatically set or clear DrvVbus register in ULPI PHY according to the port power status from the root hub<br>0: ULPI wrapper will ignore the difference between power status of root hub and ULPI PHY |
| 11    | R/W | 0x0 | AHB Master interface INCR16 enable<br>1: Use INCR16 when appropriate<br>0: Do not use INCR16, use other enabled INCRX or unspecified length burst INCR                                                                                             |
| 10    | R/W | 0x0 | AHB Master interface INCR8 enable<br>1: Use INCR8 when appropriate<br>0: Do not use INCR8, use other enabled INCRX or unspecified length burst INCR                                                                                                |
| 9     | R/W | 0x0 | AHB Master interface burst type INCR4 enable<br>1: Use INCR4 when appropriate<br>0: Do not use INCR4, use other enabled INCRX or unspecified length burst INCR                                                                                     |
| 8     | R/W | 0x0 | AHB Master interface INCRX align enable<br>1: Start INCRx burst only on burst x-align address<br>0: Start burst on any double word boundary<br>Note: This bit must enable if any bit of 11:9 is enabled                                            |
| 7:4   | /   | /   | /                                                                                                                                                                                                                                                  |
| 3     | R/W | 0x0 | RC Clock Gating<br>0: Clock gated<br>1: Clock ungated                                                                                                                                                                                              |
| 2     | R/W | 0x0 | RC Generation Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                    |
| 1     | /   | /   | /                                                                                                                                                                                                                                                  |
| 0     | R/W | 0x0 | ULPI Bypass Enable<br>1: Enable UTMI interface, disable ULPI interface<br>0: Enable ULPI interface, disable UTMI interface                                                                                                                         |

#### 10.5.7.2. 0x0808 HCI Control 3 Register(Default Value:0x0000\_0000)

| Offset: 0x808 |            |             | Register Name: HCI_CTRL3                                                                      |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                   |
| 31:17         | /          | /           | Reserved                                                                                      |
| 16            | R/W1C      | 0x1         | Linestate Change Detect<br>0: Linestate change not detected.<br>1: Linestate change detected. |

|      |     |     |                                                              |
|------|-----|-----|--------------------------------------------------------------|
|      |     |     | Write '1' to clear.                                          |
| 15:4 | /   | /   | Reserved                                                     |
| 3    | R/W | 0x0 | Remote Wakeup Enable<br>1: Enable<br>0: Disable              |
| 2    | /   | /   | Reserved                                                     |
| 1    | R/W | 0x0 | Linestate Change Interrupt Enable<br>1: Enable<br>0: Disable |
| 0    | R/W | 0x0 | Linestate Change Detect Enable<br>1: Enable<br>0: Disable    |

#### 10.5.7.3. 0x0810 PHY Control Register(Default Value: 0x0000\_0008)

| Offset: 0x0810 |            |             | Register Name: PHY_CTRL                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:17          | /          | /           | /                                                                               |
| 16             | R/W        | 0x0         | FSEL<br>PHY Clock Selection<br>0: PHY Clock is 24MHz<br>1: PHY Clock is 19.2MHz |
| 15:8           | /          | /           | /                                                                               |
| 7              | R/W        | 0x0         | LOOPBACKENB                                                                     |
| 6              | R/W        | 0x0         | IDPULLUP                                                                        |
| 5              | R/W        | 0x0         | VBUSVLDEXT (for phy vbus)<br>0: Invalid<br>1: Valid                             |
| 4              | R/W        | 0x0         | VBUSVLDEXTSEL<br>Internal signal has been tied to '1'. This bit has no effect.  |
| 3              | R/W        | 0x0         | SIDDQ<br>1: Write 1 to disable phy.<br>0: Write 0 to enable phy.                |
| 2              | R/W        | 0x0         | COMMONONN                                                                       |
| 1:0            | R/W        | 0x0         | VATESTENB                                                                       |

#### 10.5.7.4. 0x081C HSIC PHY Tune1 Register(Default Value: 0x0000\_0010)

| Offset: 0x081C |            |             | Register Name: HSIC_PHY_Tune1 |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:7           | /          | /           | /                             |
| 6:5            | /          | /           | TXRPUTUNE                     |

|     |     |     |           |
|-----|-----|-----|-----------|
| 5:4 | R/W | 0x1 | TXRPDTUNE |
| 3:0 | R/W | 0x0 | TXSRTUNE  |

#### 10.5.7.5. 0x0820 HSIC PHY Tune2 Register(Default Value: 0x0000\_0010)

| Offset: 0x0820 |            |             | Register Name: HSIC_PHY_Tune2 |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31             | /          | /           | bist_en                       |
| 30             | R/W        | 0x0         | TESTBURNIN                    |
| 29             | R/W        | 0x0         | TESTDATAOUTSEL                |
| 28             | R/W        | 0x0         | TESTCLK                       |
| 27:24          | R/W        | 0x0         | TESTADDR                      |
| 23:16          | R/W        | 0x0         | TESTDATAIN                    |
| 15:4           | R/W        | 0x1         | siddq                         |
| 3:0            | R/W        | 0x0         | refclk div                    |

#### 10.5.7.6. 0x0824 HSIC PHY Tune3 Register(Default Value: 0x0000\_0010)

| Offset: 0x0824 |            |             | Register Name: HSIC_PHY_Tune3               |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31             | /          | /           | /                                           |
| 5              | R/W        | 0x0         | hsic bist_error                             |
| 4              | R/W        | 0x0         | hsic bist_done                              |
| 3:2            | R/W        | 0x0         | hsic testdata out[3:2]                      |
| 1              | R/W        | 0x1         | Non-hsic mode bist_error<br>testdata out[1] |
| 0              | R/W        | 0x0         | Non-hsic mode bist_done<br>testdata out[0]  |

#### 10.5.7.7. 0x0828 HCI SIE Port Disable Control Register(Default Value:0x1000\_0000)

| Offset: 0x0828 |            |             | Register Name: USB_SPDCR                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:17          | /          | /           | /                                                                                                                    |
| 16             | R/W        | 0x0         | SEO Status<br>This bit is set when no-se0 is detected before SOF when bit[1:0] is 10b or 11b.                        |
| 15:5           | /          | /           | /                                                                                                                    |
| 4              | R/W        | 0x0         | resume_sel<br>When set k-se0 transition 2us, setting this bit to 1, which is cooperated with ss_utmi_backward_enb_i. |

|     |     |     |                                                                                                                                                                                                                                                                  |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:2 | /   | /   | /                                                                                                                                                                                                                                                                |
| 1:0 | R/W | 0x0 | <p>Port Disable Control<br/>00: Port Disable when no-se0 detect before SOF<br/>01: Port Disable when no-se0 detect before SOF<br/>10: No Port Disable when no-se0 detect before SOF<br/>11:Port Disable when no-se0 3 time detect before SOF during 8 frames</p> |

Confidential

## 10.6. Port Controller

### 10.6.1. Overview

The Port Controller can be configured with multi-functional input/output pins. All these ports can be configured as GPIO only if multiplexed functions are not used. The total 8 group external PIO interrupt sources are supported and interrupt mode can be configured by software.

The Port Controller has the following features:

- 8 ports(PB,PC,PD,PE,PF,PG,PH,PL)
- Software control for each signal pin
- GPIO peripheral can produce interrupt
- Pull-up/Pull-down/no-Pull register control
- Control the direction of every signal
- 4 drive strengths in each operating mode
- Up to 115 interrupts
- Configurable interrupt edges

### 10.6.2. Block Diagram

The block diagram of port controller is shown in Figure 10-33.



Figure 10- 33. Port Controller Block Diagram

Port controller consists of digital part(GPIO, external interface) and IO analog part(output buffer, dual pull down, pad, etc). Digital part can select output interface by MUX switch; analog part can configure pull up/down, buffer strength.

When executing GPIO read state, the port controller reads the current level of pin into internal register bus. When not executing GPIO read state, external pin and internal register bus is off-status, that is high-impedance.

### 10.6.3. Operations and Functional Descriptions

#### 10.6.3.1. Multi-function Port Table

The A133 includes 115 multi-functional input/output port pins. There are 8 ports as listed below:

**Table 10- 15. A133 Multi-function Port Table**

| Port Name | Number of Pins | Input Driver | Output Driver | Multiplex Pins                                              | Power       |
|-----------|----------------|--------------|---------------|-------------------------------------------------------------|-------------|
| PB        | 11             | Schmitt      | CMOS          | UART/TWI/OWA/SPI/I2S/JTAG/PWM/PB_EINT                       | 3.3 V       |
| PC        | 17             | Schmitt      | CMOS          | NAND/SMHC/SPI/PC_EINT                                       | 1.8 V/3.3 V |
| PD        | 24             | Schmitt      | CMOS          | LCD/LVDS/PWM/DSI/SPI/UART/TWI/PD_EINT                       | 1.8 V/3.3 V |
| PE        | 10             | Schmitt      | CMOS          | MIPI/TWI/CSI/PLL_LOCK_DBG/BIST_RESULT/I2S/LEDC/TCON/PE_EINT | 1.8 V/3.3 V |
| PF        | 7              | Schmitt      | CMOS          | SMHC/UART/JTAG/PF_EINT                                      | 1.8 V/3.3 V |
| PG        | 14             | Schmitt      | CMOS          | SMHC/UART/I2S/PG_EINT                                       | 1.8 V/3.3 V |
| PH        | 20             | Schmitt      | CMOS          | TWI/UART/DMIC/CIR/SPI/TWI/I2S/EMAC/LED/C/PH_EINT            | 3.3 V       |
| PL        | 12             | Schmitt      | CMOS          | UART/PWM/TWI/JTAG/S_CPU_CUR_W/PL_EINT                       | 1.8 V/3.3 V |

The multiplex function pins are shown in Table 10-16 to Table 10-23.

**Table 10- 16. PB Multiplex Function Select**

| GPIO Port | Function2 | Function3  | Function4   | Function5 | Function6 |
|-----------|-----------|------------|-------------|-----------|-----------|
| PB0       | UART2_TX  | SPI2_CS    | JTAG_MS     |           | PB_EINT0  |
| PB1       | UART2_RX  | SPI2_CLK   | JTAG_CK     |           | PB_EINT1  |
| PB2       | UART2_RTS | SPI2_MOSI  | JTAG_DO     |           | PB_EINT2  |
| PB3       | UART2_CTS | SPI2_MISO  | JTAG_DI     |           | PB_EINT3  |
| PB4       | TWI1_SCK  | I2S0_MCLK  | JTAG_MS_GPU |           | PB_EINT4  |
| PB5       | TWI1_SDA  | I2S0_BCLK  | JTAG_CK_GPU |           | PB_EINT5  |
| PB6       |           | I2S0_LRCK  | JTAG_DO_GPU |           | PB_EINT6  |
| PB7       |           | I2S0_DOUT0 | I2S0_DIN1   |           | PB_EINT7  |
| PB8       | OWA_OUT   | I2S0_DIN0  | I2S0_DOUT1  |           | PB_EINT8  |
| PB9       | UART0_TX  | TWI0_SCK   | JTAG_DI_GPU |           | PB_EINT9  |
| PB10      | UART0_RX  | TWI0_SDA   | PWM1        |           | PB_EINT10 |

**Table 10- 17. PC Multiplex Function Select**

| GPIO Port | Function2 | Function3 | Function4 | Function5 | Function6 |
|-----------|-----------|-----------|-----------|-----------|-----------|
|-----------|-----------|-----------|-----------|-----------|-----------|

|      |          |          |           |  |           |
|------|----------|----------|-----------|--|-----------|
| PC0  | NAND_WE  | SDC2_DS  |           |  | PC_EINT0  |
| PC1  | NAND_ALE | SDC2_RST |           |  | PC_EINT1  |
| PC2  | NAND_CLE |          | SPI0_MOSI |  | PC_EINT2  |
| PC3  | NAND_CE1 |          | SPI0_CS0  |  | PC_EINT3  |
| PC4  | NAND_CE0 |          | SPI0_MISO |  | PC_EINT4  |
| PC5  | NAND_RE  | SDC2_CLK |           |  | PC_EINT5  |
| PC6  | NAND_RB0 | SDC2_CMD |           |  | PC_EINT6  |
| PC7  | NAND_RB1 |          | SPI0_CS1  |  | PC_EINT7  |
| PC8  | NAND_DQ7 | SDC2_D3  |           |  | PC_EINT8  |
| PC9  | NAND_DQ6 | SDC2_D4  |           |  | PC_EINT9  |
| PC10 | NAND_DQ5 | SDC2_D0  |           |  | PC_EINT10 |
| PC11 | NAND_DQ4 | SDC2_D5  |           |  | PC_EINT11 |
| PC12 | NAND_DQS |          | SPI0_CLK  |  | PC_EINT12 |
| PC13 | NAND_DQ3 | SDC2_D1  |           |  | PC_EINT13 |
| PC14 | NAND_DQ2 | SDC2_D6  |           |  | PC_EINT14 |
| PC15 | NAND_DQ1 | SDC2_D2  | SPI0_WP   |  | PC_EINT15 |
| PC16 | NAND_DQ0 | SDC2_D7  | SPI0_HOLD |  | PC_EINT16 |

**Table 10- 18. PD Multiplex Function Select**

| GPIO Port | Function2  | Function3                  | Function4 | Function5 | Function6 |
|-----------|------------|----------------------------|-----------|-----------|-----------|
| PD0       | LCD0_D2    | LVDS0_D0P                  | DSI_DPO   |           | PD_EINT0  |
| PD1       | LCD0_D3    | LVDS0_D0N                  | DSI_DM0   |           | PD_EINT1  |
| PD2       | LCD0_D4    | LVDS0_D1P                  | DSI_DP1   |           | PD_EINT2  |
| PD3       | LCD0_D5    | LVDS0_D1N                  | DSI_DM1   |           | PD_EINT3  |
| PD4       | LCD0_D6    | LVDS0_D2P                  | DSI_CKP   |           | PD_EINT4  |
| PD5       | LCD0_D7    | LVDS0_D2N                  | DSI_CKM   |           | PD_EINT5  |
| PD6       | LCD0_D10   | LVDS0_CKP                  | DSI_DP2   |           | PD_EINT6  |
| PD7       | LCD0_D11   | LVDS0_CKN                  | DSI_DM2   |           | PD_EINT7  |
| PD8       | LCD0_D12   | LVDS0_D3P                  | DSI_DP3   |           | PD_EINT8  |
| PD9       | LCD0_D13   | LVDS0_D3N                  | DSI_DM3   |           | PD_EINT9  |
| PD10      | LCD0_D14   | LVDS1_D0P                  | SPI1_CS   |           | PD_EINT10 |
| PD11      | LCD0_D15   | LVDS1_D0N                  | SPI1_CLK  |           | PD_EINT11 |
| PD12      | LCD0_D18   | LVDS1_D1P                  | SPI1_MOSI |           | PD_EINT12 |
| PD13      | LCD0_D19   | LVDS1_D1N                  | SPI1_MISO |           | PD_EINT13 |
| PD14      | LCD0_D20   | LVDS1_D2P                  | UART3_TX  |           | PD_EINT14 |
| PD15      | LCD0_D21   | LVDS1_D2N                  | UART3_RX  |           | PD_EINT15 |
| PD16      | LCD0_D22   | LVDS1_CKP/<br>PLL_TEST_CKP | UART3_RTS |           | PD_EINT16 |
| PD17      | LCD0_D23   | LVDS1_CKN/<br>PLL_TEST_CKN | UART3_CTS |           | PD_EINT17 |
| PD18      | LCD0_CLK   | LVDS1_D3P                  | UART4_TX  |           | PD_EINT18 |
| PD19      | LCD0_DE    | LVDS1_D3N                  | UART4_RX  |           | PD_EINT19 |
| PD20      | LCD0_HSYNC | PWM2                       | UART4_RTS |           | PD_EINT20 |

|      |            |      |           |  |           |
|------|------------|------|-----------|--|-----------|
| PD21 | LCD0_VSYNC | PWM3 | UART4_CTS |  | PD_EINT21 |
| PD22 | PWM1       |      | TWI0_SCK  |  | PD_EINT22 |
| PD23 | PWM0       |      | TWI0_SDA  |  | PD_EINT23 |

**Table 10- 19. PE Multiplex Function Select**

| GPIO Port | Function2  | Function3    | Function4  | Function5 | Function6 |
|-----------|------------|--------------|------------|-----------|-----------|
| PE0       | MIPI_MCLK0 |              |            |           | PE_EINT0  |
| PE1       | TWI2_SCK   |              |            |           | PE_EINT1  |
| PE2       | TWI2_SDA   |              |            |           | PE_EINT2  |
| PE3       | TWI3_SCK   |              |            |           | PE_EINT3  |
| PE4       | TWI3_SDA   |              |            |           | PE_EINT4  |
| PE5       | MIPI_MCLK1 | PLL_LOCK_DBG | I2S2_MCLK  | LEDC      | PE_EINT5  |
| PE6       |            | BIST_RESULT0 | I2S2_BCLK  |           | PE_EINT6  |
| PE7       | CSI_SM_VS  | BIST_RESULT1 | I2S2_LRCK  |           | PE_EINT7  |
| PE8       |            | BIST_RESULT2 | I2S2_DOUT0 |           | PE_EINT8  |
| PE9       |            | BIST_RESULT3 | I2S2_DIN0  |           | PE_EINT9  |

**Table 10- 20. PF Multiplex Function Select**

| GPIO Port | Function2 | Function3 | Function4   | Function5 | Function6 |
|-----------|-----------|-----------|-------------|-----------|-----------|
| PF0       | SDC0_D1   | JTAG_MS   | JTAG_MS_GPU |           | PF_EINT0  |
| PF1       | SDC0_D0   | JTAG_DI   | JTAG_DI_GPU |           | PF_EINT1  |
| PF2       | SDC0_CLK  | UART0_TX  |             |           | PF_EINT2  |
| PF3       | SDC0_CMD  | JTAG_DO   | JTAG_DO_GPU |           | PF_EINT3  |
| PF4       | SDC0_D3   | UART0_RX  |             |           | PF_EINT4  |
| PF5       | SDC0_D2   | JTAG_CK   | JTAG_CK_GPU |           | PF_EINT5  |
| PF6       |           |           |             |           | PF_EINT6  |

**Table 10- 21. PG Multiplex Function Select**

| GPIO Port | Function2 | Function3 | Function4 | Function5 | Function6 |
|-----------|-----------|-----------|-----------|-----------|-----------|
| PG0       | SDC1_CLK  |           |           |           | PG_EINT0  |
| PG1       | SDC1_CMD  |           |           |           | PG_EINT1  |
| PG2       | SDC1_D0   |           |           |           | PG_EINT2  |
| PG3       | SDC1_D1   |           |           |           | PG_EINT3  |
| PG4       | SDC1_D2   |           |           |           | PG_EINT4  |
| PG5       | SDC1_D3   |           |           |           | PG_EINT5  |
| PG6       | UART1_TX  |           |           |           | PG_EINT6  |
| PG7       | UART1_RX  |           |           |           | PG_EINT7  |
| PG8       | UART1_RTS |           |           |           | PG_EINT8  |
| PG9       | UART1_CTS | I2S1_MCLK |           |           | PG_EINT9  |
| PG10      |           | I2S1_BCLK |           |           | PG_EINT10 |
| PG11      |           | I2S1_LRCK |           |           | PG_EINT11 |

|      |  |            |            |  |           |
|------|--|------------|------------|--|-----------|
| PG12 |  | I2S1_DOUT0 | I2S1_DIN1  |  | PG_EINT12 |
| PG13 |  | I2S1_DINO  | I2S1_DOUT1 |  | PG_EINT13 |

**Table 10- 22. PH Multiplex Function Select**

| GPIO Port | Function2  | Function3  | Function4  | Function5                     | Function6 |
|-----------|------------|------------|------------|-------------------------------|-----------|
| PH0       | TWI0_SCK   |            |            | RGMII0_RXD1/<br>RMII0_RXD1    | PH_EINT0  |
| PH1       | TWI0_SDA   |            |            | RGMII0_RXD0/<br>RMII0_RXD0    | PH_EINT1  |
| PH2       | TWI1_SCK   | CPU_CUR_W  |            | RGMII0_RXCTL/<br>RMII0_CRS_DV | PH_EINT2  |
| PH3       | TWI1_SDA   | CIR_OUT    |            | RGMII0_CLKIN/<br>RMII0_RXER   | PH_EINT3  |
| PH4       | UART3_TX   | SPI1_CS    | CPU_CUR_W  | RGMII0_TXD1/<br>RMII0_TXD1    | PH_EINT4  |
| PH5       | UART3_RX   | SPI1_CLK   | LEDC       | RGMII0_TXD0/<br>RMII0_TXD0    | PH_EINT5  |
| PH6       | UART3 RTS  | SPI1_MOSI  |            | RGMII0_TXCK/<br>RMII0_TXCK    | PH_EINT6  |
| PH7       | UART3 CTS  | SPI1_MISO  | OWA_OUT    | RGMII0_TXCTL/<br>RMII0_TXEN   | PH_EINT7  |
| PH8       | DMIC_CLK   | SPI2_CS    | I2S2_MCLK  | I2S2_DIN2                     | PH_EINT8  |
| PH9       | DMIC_DATA0 | SPI2_CLK   | I2S2_BCLK  | MDC0                          | PH_EINT9  |
| PH10      | DMIC_DATA1 | SPI2_MOSI  | I2S2_LRCK  | MDIO0                         | PH_EINT10 |
| PH11      | DMIC_DATA2 | SPI2_MISO  | I2S2_DOUT0 | I2S2_DIN1                     | PH_EINT11 |
| PH12      | DMIC_DATA3 | TWI3_SCK   | I2S2_DINO  | I2S2_DOUT1                    | PH_EINT12 |
| PH13      |            | TWI3_SDA   | I2S3_MCLK  | EPHY0_25                      | PH_EINT13 |
| PH14      |            |            | I2S3_BCLK  | RGMII0_RXD3/<br>RMII0_NULL    | PH_EINT14 |
| PH15      |            |            | I2S3_LRCK  | RGMII0_RXD2/<br>RMII0_NULL    | PH_EINT15 |
| PH16      |            | I2S3_DOUT0 | I2S3_DIN1  | RGMII0_RXCK/<br>RMII0_NULL    | PH_EINT16 |
| PH17      |            | I2S3_DOUT1 | I2S3_DINO  | RGMII0_TXD3/<br>RMII0_NULL    | PH_EINT17 |
| PH18      | CIR_OUT    | I2S3_DOUT2 | I2S3_DIN2  | RGMII0_TXD2/<br>RMII0_NULL    | PH_EINT18 |
| PH19      | CIR_IN     | I2S3_DOUT3 | I2S3_DIN3  | LEDC                          | PH_EINT19 |

**Table 10- 23. PL Multiplex Function Select**

| GPIO Port | Function2  | Function3 | Function4 | Function5 | Function6  |
|-----------|------------|-----------|-----------|-----------|------------|
| PL0       | S_TWI0_SCK |           |           |           | S_PL_EINT0 |

|      |             |          |  |  |             |
|------|-------------|----------|--|--|-------------|
| PL1  | S_TWIO_SDA  |          |  |  | S_PL_EINT1  |
| PL2  | S_UART_TX   |          |  |  | S_PL_EINT2  |
| PL3  | S_UART_RX   |          |  |  | S_PL_EINT3  |
| PL4  | S_JTAG_MS   |          |  |  | S_PL_EINT4  |
| PL5  | S_JTAG_CK   |          |  |  | S_PL_EINT5  |
| PL6  | S_JTAG_DO   |          |  |  | S_PL_EINT6  |
| PL7  | S_JTAG_DI   |          |  |  | S_PL_EINT7  |
| PL8  | S_TWI1_SCK  |          |  |  | S_PL_EINT8  |
| PL9  | S_TWI1_SDA  |          |  |  | S_PL_EINT9  |
| PL10 | S_PWM       |          |  |  | S_PL_EINT10 |
| PL11 | S_CPU_CUR_W | S_CIR_IN |  |  | S_PL_EINT11 |

#### 10.6.3.2. Port Function

Port Controller supports 8 GPIOs, every GPIO can configure as Input, Output, Functional Peripheral, IO disable or Interrupt function. The configuration instruction of every function is as follows.

Table 10- 24. Port Function

|           | Function                              | Buffer Strength | Pull Up | Pull Down |
|-----------|---------------------------------------|-----------------|---------|-----------|
| Input     | Input function,<br>default input is 0 | /               | N       | Y         |
|           | Input function,<br>default input is 1 | /               | Y       | N         |
| Output    | Output function                       | Y               | X       | X         |
| Disable   | Pull-up                               | /               | Y       | N         |
|           | Pull-down                             | /               | N       | Y         |
|           | High-impedance                        | /               | N       | N         |
| Interrupt | Trigger mode                          | /               | X       | X         |

/: Non-configure, configuration is invalid

Y: Need configure

X: Select configuration according to actual situation

N: Forbid to configure.

#### 10.6.3.3. Pull Up/Down and High-Impedance Logic

Each IO pin can configure the internal pull-up/down function or high-impedance.



**Figure 10- 34. Pull up/down Logic**

High-impedance, the output is float state, all buffers are off, the level is decided by external high/low level. When high-impedance, software configures the switch on Rpu and Rpd as off, and the multiplexing function of IO is set as IO disable or input by software.

Pull-up, an uncertain signal is pulled high by a resistance, the resistance has current-limiting function. When pulling up, the switch on Rpu is breakover by software configuration, IO is pulled up to VCC by Rpu.

Pull-down, an uncertain signal is pulled low by a resistance. When pulling down, the switch on Rpd is breakover by software configuration, IO is pulled down to GND by Rpd.

The pull-up/down of each IO is weak pull-up/down, the resistance value is about 100 kΩ.

The setting of pull-down input, pull-up input, high-impedance input is decided by external circuit.

#### 10.6.3.4. Buffer Strength

Each IO can be set as different buffer strength. The IO buffer diagram is as follows.



**Figure 10- 35. IO Buffer Strength Diagram**

When output high level, the n0,n1,n2,n3 of NMOS are off, the p0,p1,p2,p3 of PMOS are on. When buffer strength is set to 0(buffer strength is weakest), only p0 is on, the output impedance is maximum, the impedance value is r0 (on-resistance). When buffer strength is set to 1, only p0 and p1 are on, the output impedance is equivalent to two r0 in parallel, the impedance value is r0/2. When buffer strength is 2, only p0,p1 and p2 are on, the output impedance is equivalent to three r0 in parallel, the impedance value is r0/3. When buffer strength is 3, p0,p1,p2 and p3 are on, the output impedance is equivalent to four r0 in parallel, the impedance value is r0/4.

When output low level, the p0,p1,p2,p3 of PMOS is off, the n0,n1,n2,n3 of NMOS is on. When buffer strength is set to 0(buffer strength is weakest), only n0 is on, the output impedance is maximum, the impedance value is r0. When buffer strength is set to 1, only n0 and n1 are on, the output impedance is equivalent to two r0 in parallel, the impedance value is r0/2. When buffer strength is 2, only n0,n1 and n2 are on, the output impedance is equivalent to three r0 in parallel, the impedance value is r0/3. When buffer strength is 3, n0,n1,n2 and n3 are on, the output impedance is equivalent to four r0 in parallel, the impedance value is r0/4.

When GPIO is set to input or interrupt function, between the output driver circuit and the port is unconnected, the driver configuration is invalid.

#### 10.6.3.5. Interrupt

Each group IO has independent interrupt number. IO within group uses one interrupt number, when one IO generates interrupt, Port Controller sent interrupt request to GIC. External Interrupt Status Register is used to query which IO generates interrupt.

Interrupt trigger of GPIO supports the following trigger types.

- Positive Edge: When low level changes to high level, the interrupt will generate. No matter how long high level keeps, the interrupt generates only once.
- Negative Edge: When high level changes to low level, the interrupt will generate. No matter how long low level keeps, the interrupt generates only once.
- High Level : Just keep high level and the interrupt will always generate.
- Low Level : Just keep low level and the interrupt will always generate.
- Double Edge : Positive and negative edge.

External Interrupt Configure Register is used to configure trigger type.

GPIO interrupt supports hardware debounce function by setting External Interrupt Debounce Register. Sample trigger signal using lower sample clock, to reach the debounce effect because of the dither frequency of signal is higher than sample frequency.

Set sample clock source by PIO\_INT\_CLK\_SELECT and prescale factor by DEB\_CLK\_PRE\_SCALE.

#### 10.6.4. Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|                            |            |
|----------------------------|------------|
| GPIO(PB,PC,PD,PE,PF,PG,PH) | 0x0300B000 |
|----------------------------|------------|

| Register Name   | Offset            | Description                                              |
|-----------------|-------------------|----------------------------------------------------------|
| Pn_CFG0         | n*0x24+0x00       | Port n Configure Register 0 (n =1,2,3,4,5,6,7)           |
| Pn_CFG1         | n*0x24+0x04       | Port n Configure Register 1 (n =1,2,3,4,5,6,7)           |
| Pn_CFG2         | n*0x24+0x08       | Port n Configure Register 2 (n =1,2,3,4,5,6,7)           |
| Pn_CFG3         | n*0x24+0x0C       | Port n Configure Register 3 (n =1,2,3,4,5,6,7)           |
| Pn_DAT          | n*0x24+0x10       | Port n Data Register (n =1,2,3,4,5,6,7)                  |
| Pn_DRV0         | n*0x24+0x14       | Port n Multi-Driving Register 0 (n =1,2,3,4,5,6,7)       |
| Pn_DRV1         | n*0x24+0x18       | Port n Multi-Driving Register 1 (n =1,2,3,4,5,6,7)       |
| Pn_PUL0         | n*0x24+0x1C       | Port n Pull Register 0 (n =1,2,3,4,5,6,7)                |
| Pn_PUL1         | n*0x24+0x20       | Port n Pull Register 1 (n =1,2,3,4,5,6,7)                |
| Pn_INT_CFG0     | 0x200+n*0x20+0x00 | PIO Interrupt Configure Register 0 (n =1,2,3,4,5,6,7)    |
| Pn_INT_CFG1     | 0x200+n*0x20+0x04 | PIO Interrupt Configure Register 1 (n =1,2,3,4,5,6,7)    |
| Pn_INT_CFG2     | 0x200+n*0x20+0x08 | PIO Interrupt Configure Register 2 (n =1,2,3,4,5,6,7)    |
| Pn_INT_CFG3     | 0x200+n*0x20+0x0C | PIO Interrupt Configure Register 3 (n =1,2,3,4,5,6,7)    |
| Pn_INT_CTL      | 0x200+n*0x20+0x10 | PIO Interrupt Control Register (n =1,2,3,4,5,6,7)        |
| Pn_INT_STA      | 0x200+n*0x20+0x14 | PIO Interrupt Status Register (n =1,2,3,4,5,6,7)         |
| Pn_INT_DEB      | 0x200+n*0x20+0x18 | PIO Interrupt Debounce Register (n =1,2,3,4,5,6,7)       |
| PIO_POW_MOD_SEL | 0x0340            | PIO Group Withstand Voltage Mode Select Register         |
| PIO_POW_MS_CTL  | 0x0344            | PIO Group Withstand Voltage Mode Select Control Register |
| PIO_POW_VAL     | 0x0348            | PIO Group Power Value Register                           |

| Module Name | Base Address |
|-------------|--------------|
| GPIO(PL)    | 0x07022000   |

| Register Name | Offset            | Description                               |
|---------------|-------------------|-------------------------------------------|
| Pn_CFG0       | n*0x24+0x00       | Port n Configure Register 0 (n =0)        |
| Pn_CFG1       | n*0x24+0x04       | Port n Configure Register 1 (n =0)        |
| Pn_CFG2       | n*0x24+0x08       | Port n Configure Register 2 (n =0)        |
| Pn_CFG3       | n*0x24+0x0C       | Port n Configure Register 3 (n =0)        |
| Pn_DAT        | n*0x24+0x10       | Port n Data Register (n =0)               |
| Pn_DRV0       | n*0x24+0x14       | Port n Multi_Driving Register 0 (n =0)    |
| Pn_DRV1       | n*0x24+0x18       | Port n Multi_Driving Register 1 (n =0)    |
| Pn_PUL0       | n*0x24+0x1C       | Port n Pull Register 0 (n =0)             |
| Pn_PUL1       | n*0x24+0x20       | Port n Pull Register 1 (n =0)             |
| Pn_INT_CFG0   | 0x200+n*0x20+0x00 | PIO Interrupt Configure Register 0 (n =0) |
| Pn_INT_CFG1   | 0x200+n*0x20+0x04 | PIO Interrupt Configure Register 1 (n =0) |
| Pn_INT_CFG2   | 0x200+n*0x20+0x08 | PIO Interrupt Configure Register 2 (n =0) |
| Pn_INT_CFG3   | 0x200+n*0x20+0x0C | PIO Interrupt Configure Register 3 (n =0) |

|                 |                   |                                                          |
|-----------------|-------------------|----------------------------------------------------------|
| Pn_INT_CTL      | 0x200+n*0x20+0x10 | PIO Interrupt Control Register (n =0)                    |
| Pn_INT_STA      | 0x200+n*0x20+0x14 | PIO Interrupt Status Register (n =0)                     |
| Pn_INT_DEB      | 0x200+n*0x20+0x18 | PIO Interrupt Debounce Register (n =0)                   |
| PIO_POW_MOD_SEL | 0x0340            | PIO Group Withstand Voltage Mode Select Register         |
| PIO_POW_MS_CTL  | 0x0344            | PIO Group Withstand Voltage Mode Select Control Register |
| PIO_POW_VAL     | 0x0348            | PIO Group Power Value Register                           |

## 10.6.5. GPIO(PB,PC,PD,PE,PF,PG,PH) Register Description

### 10.6.5.1. 0x0024 PB Configure Register 0 (Default Value: 0x7777\_7777)

| Offset: 0x0024 |            |             | Register Name: PB_CFG0                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31             | /          | /           | /                                                                          |
| 30:28          | R/W        | 0x7         | PB7_SELECT<br>000:Input<br>010:Reserved<br>100:I2SO_DIN1<br>110:PB_EINT7   |
| 27             | /          | /           | /                                                                          |
| 26:24          | R/W        | 0x7         | PB6_SELECT<br>000:Input<br>010:Reserved<br>100:JTAG_DO_GPU<br>110:PB_EINT6 |
| 23             | /          | /           | /                                                                          |
| 22:20          | R/W        | 0x7         | PB5_SELECT<br>000:Input<br>010:TWI1_SDA<br>100:JTAG_CK_GPU<br>110:PB_EINT5 |
| 19             | /          | /           | /                                                                          |
| 18:16          | R/W        | 0x7         | PB4_SELECT<br>000:Input<br>010:TWI1_SCK<br>100:JTAG_MS_GPU<br>110:PB_EINT4 |
| 15             | /          | /           | /                                                                          |
| 14:12          | R/W        | 0x7         | PB3_SELECT<br>000:Input<br>010:UART2_CTS<br>100:JTAG_DI                    |

|      |     |     |                                                                         |                                                               |
|------|-----|-----|-------------------------------------------------------------------------|---------------------------------------------------------------|
|      |     |     | 110:PB_EINT3                                                            | 111:IO Disable                                                |
| 11   | /   | /   | /                                                                       |                                                               |
| 10:8 | R/W | 0x7 | PB2_SELECT<br>000:Input<br>010:UART2_RTS<br>100:JTAG_DO<br>110:PB_EINT2 | 001:Output<br>011:SPI2_MOSI<br>101:Reserved<br>111:IO Disable |
| 7    | /   | /   | /                                                                       |                                                               |
| 6:4  | R/W | 0x7 | PB1_SELECT<br>000:Input<br>010:UART2_RX<br>100:JTAG_CLK<br>110:PB_EINT1 | 001:Output<br>011:SPI2_CLK<br>101:Reserved<br>111:IO Disable  |
| 3    | /   | /   | /                                                                       |                                                               |
| 2:0  | R/W | 0x7 | PB0_SELECT<br>000:Input<br>010:UART2_TX<br>100:JTAG_MS<br>110:PB_EINT0  | 001:Output<br>011:SPI2_CS<br>101:Reserved<br>111:IO Disable   |

#### 10.6.5.2. 0x0028 PB Configure Register 1 (Default Value: 0x0000\_0777)

| Offset: 0x0028 |            |             | Register Name: PB_CFG1                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:11          | /          | /           | /                                                                          |
| 10:8           | R/W        | 0x7         | PB10_SELECT<br>000:Input<br>010:UART0_RX<br>100:PWM1<br>110:PB_EINT10      |
| 7              | /          | /           | /                                                                          |
| 6:4            | R/W        | 0x7         | PB9_SELECT<br>000:Input<br>010:UART0_TX<br>100:JTAG_DI_GPU<br>110:PB_EINT9 |
| 3              | /          | /           | /                                                                          |
| 2:0            | R/W        | 0x7         | PB8_SELECT<br>000:Input<br>010:OWA_OUT<br>100:I2SO_DOUT1<br>110:PB_EINT8   |

#### 10.6.5.3. 0x0034 PB Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: PB_DAT                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                         |
| 31:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 10:0           | R/W        | 0           | PB_DAT<br>If the port is configured as input, the corresponding bit is the pin state.<br>If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.4. 0x0038 PB Multi-Driving Register 0 (Default Value: 0x0015\_5555)

| Offset: 0x0038 |            |             | Register Name: PB_DRV0                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:22          | /          | /           | /                                                                                           |
| 21:20          | R/W        | 0x1         | PB10_DRV<br>PB10 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | R/W        | 0x1         | PB9_DRV<br>PB9 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 17:16          | R/W        | 0x1         | PB8_DRV<br>PB8 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 15:14          | R/W        | 0x1         | PB7_DRV<br>PB7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 13:12          | R/W        | 0x1         | PB6_DRV<br>PB6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 11:10          | R/W        | 0x1         | PB5_DRV<br>PB5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 9:8            | R/W        | 0x1         | PB4_DRV<br>PB4 Multi_Driving Select                                                         |

|     |     |     |                                                                   |                            |
|-----|-----|-----|-------------------------------------------------------------------|----------------------------|
|     |     |     | 00: Level 0<br>10: Level 2                                        | 01: Level 1<br>11: Level 3 |
| 7:6 | R/W | 0x1 | PB3_DRV<br>PB3 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 5:4 | R/W | 0x1 | PB2_DRV<br>PB2 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 3:2 | R/W | 0x1 | PB1_DRV<br>PB1 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 1:0 | R/W | 0x1 | PB0_DRV<br>PB0 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |

#### 10.6.5.5. 0x0040 PB Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: PB_PULL0                                                            |                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |                             |
| 31:22          | /          | /           | /                                                                                  |                             |
| 21:20          | R/W        | 0x0         | PB10_PULL<br>PB10 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down | 01: Pull_up<br>11: Reserved |
| 19:18          | R/W        | 0x0         | PB9_PULL<br>PB9 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down   | 01: Pull_up<br>11: Reserved |
| 17:16          | R/W        | 0x0         | PB8_PULL<br>PB8 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down   | 01: Pull_up<br>11: Reserved |
| 15:14          | R/W        | 0x0         | PB7_PULL<br>PB7 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down   | 01: Pull_up<br>11: Reserved |
| 13:12          | R/W        | 0x0         | PB6_PULL<br>PB6 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down   | 01: Pull_up<br>11: Reserved |

|       |     |     |                                                                                                                     |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------|
| 11:10 | R/W | 0x0 | PB5_PULL<br>PB5 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 9:8   | R/W | 0x0 | PB4_PULL<br>PB4 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 7:6   | R/W | 0x0 | PB3_PULL<br>PB3 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 5:4   | R/W | 0x0 | PB2_PULL<br>PB2 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 3:2   | R/W | 0x0 | PB1_PULL<br>PB1 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 1:0   | R/W | 0x0 | PB0_PULL<br>PB0 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |

#### 10.6.5.6. 0x0048 PC Configure Register 0 (Default Value: 0x7777\_7777)

| Offset: 0x0048 |            |             | Register Name: PC_CFG0                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                     |
| 31             | /          | /           | /                                                                                                                                                                                                                               |
| 30:28          | R/W        | 0x7         | PC7_SELECT<br>000:Input                          001:Output<br>010:NAND_RB1                          011:Reserved<br>100:SPIO_CS1                          101:Reserved<br>110:PC_EINT7                          111:IO Disable |
| 27             | /          | /           | /                                                                                                                                                                                                                               |
| 26:24          | R/W        | 0x7         | PC6_SELECT<br>000:Input                          001:Output<br>010:NAND_RB0                          011:SDC2_CMD<br>100:Reserved                          101:Reserved<br>110:PC_EINT6                          111:IO Disable |
| 23             | /          | /           | /                                                                                                                                                                                                                               |
| 22:20          | R/W        | 0x7         | PC5_SELECT                                                                                                                                                                                                                      |

|       |     |     |                                                                          |                                                              |
|-------|-----|-----|--------------------------------------------------------------------------|--------------------------------------------------------------|
|       |     |     | 000:Input<br>010:NAND_RE<br>100:Reserved<br>110:PC_EINT5                 | 001:Output<br>011:SDC2_CLK<br>101:Reserved<br>111:IO Disable |
| 19    | /   | /   | /                                                                        |                                                              |
| 18:16 | R/W | 0x7 | PC4_SELECT<br>000:Input<br>010:NAND_CE0<br>100:SPIO_MISO<br>110:PC_EINT4 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 15    | /   | /   | /                                                                        |                                                              |
| 14:12 | R/W | 0x7 | PC3_SELECT<br>000:Input<br>010:NAND_CE1<br>100:SPIO_CS0<br>110:PC_EINT3  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 11    | /   | /   | /                                                                        |                                                              |
| 10:8  | R/W | 0x7 | PC2_SELECT<br>000:Input<br>010:NAND_CLE<br>100:SPIO莫斯I<br>110:PC_EINT2   | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 7     | /   | /   | /                                                                        |                                                              |
| 6:4   | R/W | 0x7 | PC1_SELECT<br>000:Input<br>010:NAND_ALE<br>100:Reserved<br>110:PC_EINT1  | 001:Output<br>011:SDC2_RST<br>101:Reserved<br>111:IO Disable |
| 3     | /   | /   | /                                                                        |                                                              |
| 2:0   | R/W | 0x7 | PC0_SELECT<br>000:Input<br>010:NAND_WE<br>100:Reserved<br>110:PC_EINT0   | 001:Output<br>011:SDC2_DS<br>101:Reserved<br>111:IO Disable  |

#### 10.6.5.7. 0x004C PC Configure Register 1 (Default Value: 0x7777\_7777)

| Offset: 0x004C |            |             | Register Name: PC_CFG1                   |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |
| 31             | /          | /           | /                                        |
| 30:28          | R/W        | 0x7         | PC15_SELECT<br>000:Input<br>010:NAND_DQ1 |

|       |     |     |                                                                           |                                                              |
|-------|-----|-----|---------------------------------------------------------------------------|--------------------------------------------------------------|
|       |     |     | 100:SPI0_WP<br>110:PC_EINT15                                              | 101:Reserved<br>111:IO Disable                               |
| 27    | /   | /   | /                                                                         |                                                              |
| 26:24 | R/W | 0x7 | PC14_SELECT<br>000:Input<br>010:NAND_DQ2<br>100:Reserved<br>110:PC_EINT14 | 001:Output<br>011:SDC2_D6<br>101:Reserved<br>111:IO Disable  |
| 23    | /   | /   | /                                                                         |                                                              |
| 22:20 | R/W | 0x7 | PC13_SELECT<br>000:Input<br>010:NAND_DQ3<br>100:Reserved<br>110:PC_EINT13 | 001:Output<br>011:SDC2_D1<br>101:Reserved<br>111:IO Disable  |
| 19    | /   | /   | /                                                                         |                                                              |
| 18:16 | R/W | 0x7 | PC12_SELECT<br>000:Input<br>010:NAND_DQS<br>100:SPI0_CLK<br>110:PC_EINT12 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 15    | /   | /   | /                                                                         |                                                              |
| 14:12 | R/W | 0x7 | PC11_SELECT<br>000:Input<br>010:NAND_DQ4<br>100:Reserved<br>110:PC_EINT11 | 001:Output<br>011:SDC2_D5<br>101:Reserved<br>111:IO Disable  |
| 11    | /   | /   | /                                                                         |                                                              |
| 10:8  | R/W | 0x7 | PC10_SELECT<br>000:Input<br>010:NAND_DQ5<br>100:Reserved<br>110:PC_EINT10 | 001:Output<br>011:SDC2_D0<br>101:Reserved<br>111:IO Disable  |
| 7     | /   | /   | /                                                                         |                                                              |
| 6:4   | R/W | 0x7 | PC9_SELECT<br>000:Input<br>010:NAND_DQ6<br>100:Reserved<br>110:PC_EINT9   | 001:Output<br>011:SDC2_D4<br>101:Reserved<br>111:IO Disable  |
| 3     | /   | /   | /                                                                         |                                                              |
| 2:0   | R/W | 0x7 | PC8_SELECT<br>000:Input<br>010:NAND_DQ7<br>100:Reserved<br>110:PC_EINT8   | 001:Output<br>011:SDC2_D3<br>101:Reserved<br>111:IO Disable  |

#### 10.6.5.8. 0x0050 PC Configure Register 2 (Default Value: 0x0000\_0007)

| Offset: 0x0050 |            |             | Register Name: PC_CFG2                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31:3           | /          | /           | /                                                                                                                             |
| 2:0            | R/W        | 0x7         | PC16_SELECT<br>000:Input 001:Output<br>010:NAND_DQ0 011:SDC2_D7<br>100:SPI0_HOLD 100:Reserved<br>110:PC_EINT16 111:IO Disable |

#### 10.6.5.9. 0x0058 PC Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: PC_DAT                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                         |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 16:0           | R/W        | 0x0         | PC_DAT<br>If the port is configured as input, the corresponding bit is the pin state.<br>If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.10. 0x005C PC Multi-Driving Register 0 (Default Value: 0x5555\_5555)

| Offset: 0x005C |            |             | Register Name: PC_DRV0                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:30          | R/W        | 0x1         | PC15_DRV<br>PC15 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 29:28          | R/W        | 0x1         | PC14_DRV<br>PC14 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | R/W        | 0x1         | PC13_DRV<br>PC13 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 25:24          | R/W        | 0x1         | PC12_DRV<br>PC12 Multi-Driving Select<br>00: Level 0 01: Level 1                            |

|       |     |     |                                                                                             |
|-------|-----|-----|---------------------------------------------------------------------------------------------|
|       |     |     | 10: Level 2<br>11: Level 3                                                                  |
| 23:22 | R/W | 0x1 | PC11_DRV<br>PC11 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 21:20 | R/W | 0x1 | PC10_DRV<br>PC10 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18 | R/W | 0x1 | PC9_DRV<br>PC9 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 17:16 | R/W | 0x1 | PC8_DRV<br>PC8 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 15:14 | R/W | 0x1 | PC7_DRV<br>PC7 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 13:12 | R/W | 0x1 | PC6_DRV<br>PC6 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 11:10 | R/W | 0x1 | PC5_DRV<br>PC5 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 9:8   | R/W | 0x1 | PC4_DRV<br>PC4 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 7:6   | R/W | 0x1 | PC3_DRV<br>PC3 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 5:4   | R/W | 0x1 | PC2_DRV<br>PC2 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 3:2   | R/W | 0x1 | PC1_DRV<br>PC1 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |

|     |     |     |                                                                                           |
|-----|-----|-----|-------------------------------------------------------------------------------------------|
| 1:0 | R/W | 0x1 | PC0_DRV<br>PC0 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
|-----|-----|-----|-------------------------------------------------------------------------------------------|

#### 10.6.5.11. 0x0060 PC Multi-Driving Register 1 (Default Value: 0x0000\_0001)

| Offset: 0x0060 |            |             | Register Name: PC_DRV1                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:2           | /          | /           | /                                                                                           |
| 1:0            | R/W        | 0x1         | PC16_DRV<br>PC16 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 10.6.5.12. 0x0064 PC Pull Register 0 (Default Value: 0x0000\_5140)

| Offset: 0x0064 |            |             | Register Name: PC_PULL0                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:30          | R/W        | 0x0         | PC15_PULL<br>PC15 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 29:28          | R/W        | 0x0         | PC14_PULL<br>PC14 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 27:26          | R/W        | 0x0         | PC13_PULL<br>PC13 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 25:24          | R/W        | 0x0         | PC12_PULL<br>PC12 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 23:22          | R/W        | 0x0         | PC11_PULL<br>PC11 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 21:20          | R/W        | 0x0         | PC10_PULL<br>PC10 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up                               |

|       |     |     |                                                                                  |                             |
|-------|-----|-----|----------------------------------------------------------------------------------|-----------------------------|
|       |     |     | 10: Pull-down                                                                    | 11: Reserved                |
| 19:18 | R/W | 0x0 | PC9_PULL<br>PC9 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 17:16 | R/W | 0x0 | PC8_PULL<br>PC8 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 15:14 | R/W | 0x1 | PC7_PULL<br>PC7 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 13:12 | R/W | 0x1 | PC6_PULL<br>PC6 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 11:10 | R/W | 0x0 | PC5_PULL<br>PC5 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 9:8   | R/W | 0x1 | PC4_PULL<br>PC4 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 7:6   | R/W | 0x1 | PC3_PULL<br>PC3 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 5:4   | R/W | 0x0 | PC2_PULL<br>PC2 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 3:2   | R/W | 0x0 | PC1_PULL<br>PC1 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 1:0   | R/W | 0x0 | PC0_PULL<br>PC0 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |

**10.6.5.13. 0x0068 PC Pull Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0068 |            |             | Register Name: PC_PULL1                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:2           | /          | /           | /                                                                                                                     |
| 1:0            | R/W        | 0x0         | PC16_PULL<br>PC16 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |

**10.6.5.14. 0x006C PD Configure Register 0 (Default Value: 0x7777\_7777)**

| Offset: 0x006C |            |             | Register Name: PD_CFG0                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 31             | /          | /           | /                                                                                                                                              |
| 30:28          | R/W        | 0x7         | PD7_SELECT<br>000:Input      001:Output<br>010:LCD_D11      011:LVDS0_CKN<br>100:DSI_DM2      101:Reserved<br>110:PD_EINT7      111:IO Disable |
| 27             | /          | /           | /                                                                                                                                              |
| 26:24          | R/W        | 0x7         | PD6_SELECT<br>000:Input      001:Output<br>010:LCD_D10      011:LVDS0_CKP<br>100:DSI_DP2      101:Reserved<br>110:PD_EINT6      111:IO Disable |
| 23             | /          | /           | /                                                                                                                                              |
| 22:20          | R/W        | 0x7         | PD5_SELECT<br>000:Input      001:Output<br>010:LCD_D7      011:LVDS0_D2N<br>100:DSI_CKM      101:Reserved<br>110:PD_EINT5      111:IO Disable  |
| 19             | /          | /           | /                                                                                                                                              |
| 18:16          | R/W        | 0x7         | PD4_SELECT<br>000:Input      001:Output<br>010:LCD_D6      011:LVDS0_D2P<br>100:DSI_CKP      101:Reserved<br>110:PD_EINT4      111:IO Disable  |
| 15             | /          | /           | /                                                                                                                                              |
| 14:12          | R/W        | 0x7         | PD3_SELECT<br>000:Input      001:Output<br>010:LCD_D5      011:LVDS0_D1N<br>100:DSI_DM1      101:Reserved                                      |

|      |     |     |                                                                      |                                                               |
|------|-----|-----|----------------------------------------------------------------------|---------------------------------------------------------------|
|      |     |     | 110:PD_EINT3                                                         | 111:IO Disable                                                |
| 11   | /   | /   | /                                                                    |                                                               |
| 10:8 | R/W | 0x7 | PD2_SELECT<br>000:Input<br>010:LCD_D4<br>100:DSI_DP1<br>110:PD_EINT2 | 001:Output<br>011:LVDS0_D1P<br>101:Reserved<br>111:IO Disable |
| 7    | /   | /   | /                                                                    |                                                               |
| 6:4  | R/W | 0x7 | PD1_SELECT<br>000:Input<br>010:LCD_D3<br>100:DSI_DM0<br>110:PD_EINT1 | 001:Output<br>011:LVDS0_D0N<br>101:Reserved<br>111:IO Disable |
| 3    | /   | /   | /                                                                    |                                                               |
| 2:0  | R/W | 0x7 | PDO_SELECT<br>000:Input<br>010:LCD_D2<br>100:DSI_DPO<br>110:PD_EINT0 | 001:Output<br>011:LVDS0_D0P<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.15. 0x0070 PD Configure Register 1 (Default Value: 0x7777\_7777)

| Offset: 0x0070 |            |             | Register Name: PD_CFG1                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31             | /          | /           | /                                                                          |
| 30:28          | R/W        | 0x7         | PD15_SELECT<br>000:Input<br>010:LCD0_D21<br>100:UART3_RX<br>110:PD_EINT15  |
| 27             | /          | /           | /                                                                          |
| 26:24          | R/W        | 0x7         | PD14_SELECT<br>000:Input<br>010:LCD0_D20<br>100:UART3_TX<br>110:PD_EINT14  |
| 23             | /          | /           | /                                                                          |
| 22:20          | R/W        | 0x7         | PD13_SELECT<br>000:Input<br>010:LCD0_D19<br>100:SPI1_MISO<br>110:PD_EINT13 |
| 19             | /          | /           | /                                                                          |

|       |     |     |                                                                           |                                                                |
|-------|-----|-----|---------------------------------------------------------------------------|----------------------------------------------------------------|
| 18:16 | R/W | 0x7 | PD12_SELECT<br>000:Input<br>010:LCD_D18<br>100:SPI1_MOSI<br>110:PD_EINT12 | 001:Output<br>011:LVDS1_D1P<br>101:Reserved<br>111:IO Disable  |
| 15    | /   | /   | /                                                                         |                                                                |
| 14:12 | R/W | 0x7 | PD11_SELECT<br>000:Input<br>010:LCD0_D15<br>100:SPI1_CLK<br>110:PD_EINT11 | 001:Output<br>011:LVDS1_D0N<br>101:Reserved<br>111:IO Disable  |
| 11    | /   | /   | /                                                                         |                                                                |
| 10:8  | R/W | 0x7 | PD10_SELECT<br>000:Input<br>010:LCD0_D14<br>100:SPI1_CS<br>110:PD_EINT10  | 001:Output<br>011:LVDS1_D0P<br>101:Reserved<br>111:IO Disable  |
| 7     | /   | /   | /                                                                         |                                                                |
| 6:4   | R/W | 0x7 | PD9_SELECT<br>000:Input<br>010:LCD0_D13<br>100:DSI_DM3<br>110:PD_EINT9    | 001:Output<br>011: LVDS0_D3N<br>101:Reserved<br>111:IO Disable |
| 3     | /   | /   | /                                                                         |                                                                |
| 2:0   | R/W | 0x7 | PD8_SELECT<br>000:Input<br>010:LCD0_D12<br>100:DSI_DP3<br>110:PD_EINT8    | 001:Output<br>011:LVDS0_D3P<br>101:Reserved<br>111:IO Disable  |

#### 10.6.5.16. 0x0074 PD Configure Register 2 (Default Value: 0x7777\_7777)

| Offset: 0x0074 |            |             | Register Name: PD_CFG2                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31             | /          | /           | /                                                                     |
| 30:28          | R/W        | 0x7         | PD23_SELECT<br>000:Input<br>010:PWM0<br>100:TWI0_SDA<br>110:PD_EINT23 |
| 27             | /          | /           | /                                                                     |
| 26:24          | R/W        | 0x7         | PD22_SELECT<br>000:Input                                              |
|                |            |             | 001:Output                                                            |

|       |     |     |                                                                              |                                                                            |
|-------|-----|-----|------------------------------------------------------------------------------|----------------------------------------------------------------------------|
|       |     |     | 010:PWM1<br>100:TWI0_SCK<br>110:PD_EINT22                                    | 011:Reserved<br>101:Reserved<br>111:IO Disable                             |
| 23    | /   | /   | /                                                                            |                                                                            |
| 22:20 | R/W | 0x7 | PD21_SELECT<br>000:Input<br>010:LCD0_VSYNC<br>100:UART4_CTS<br>110:PD_EINT21 | 001:Output<br>011:PWM3<br>101:Reserved<br>111:IO Disable                   |
| 19    | /   | /   | /                                                                            |                                                                            |
| 18:16 | R/W | 0x7 | PD20_SELECT<br>000:Input<br>010:LCD0_HSYNC<br>100:UART4 RTS<br>110:PD_EINT20 | 001:Output<br>011:PWM2<br>101:Reserved<br>111:IO Disable                   |
| 15    | /   | /   | /                                                                            |                                                                            |
| 14:12 | R/W | 0x7 | PD19_SELECT<br>000:Input<br>010:LCD0_DE<br>100:UART4_RX<br>110:PD_EINT19     | 001:Output<br>011:LVDS1_D3N<br>101:Reserved<br>111:IO Disable              |
| 11    | /   | /   | /                                                                            |                                                                            |
| 10:8  | R/W | 0x7 | PD18_SELECT<br>000:Input<br>010:LCD0_CLK<br>100:UART4_TX<br>110:PD_EINT18    | 001:Output<br>011:LVDS1_D3P<br>101:Reserved<br>111:IO Disable              |
| 7     | /   | /   | /                                                                            |                                                                            |
| 6:4   | R/W | 0x7 | PD17_SELECT<br>000:Input<br>010:LCD0_D23<br>100:UART3_CTS<br>110:PD_EINT17   | 001:Output<br>011:LVDS1_CKN/PLL_TEST_CKN<br>101:Reserved<br>111:IO Disable |
| 3     | /   | /   | /                                                                            |                                                                            |
| 2:0   | R/W | 0x7 | PD16_SELECT<br>000:Input<br>010:LCD0_D22<br>100:UART3_RTS<br>110:PD_EINT16   | 001:Output<br>011:LVDS1_CKP/PLL_TEST_CKP<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.17. 0x007C PD Data Register (Default Value: 0x0000\_0000)

|                |                       |
|----------------|-----------------------|
| Offset: 0x007C | Register Name: PD_DAT |
|----------------|-----------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                      |
|-------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | /          | /           | /                                                                                                                                                                                                                                                                                                                |
| 23:0  | R/W        | 0x0         | PD_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.18. 0x0080 PD Multi-Driving Register 0 (Default Value: 0x5555\_5555)

| Offset: 0x0080 |            |             | Register Name: PD_DRV0                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:30          | R/W        | 0x1         | PD15_DRV<br>PD15 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 29:28          | R/W        | 0x1         | PD14_DRV<br>PD14 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | R/W        | 0x1         | PD13_DRV<br>PD13 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 25:24          | R/W        | 0x1         | PD12_DRV<br>PD12 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | R/W        | 0x1         | PD11_DRV<br>PD11 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 21:20          | R/W        | 0x1         | PD10_DRV<br>PD10 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | R/W        | 0x1         | PD9_DRV<br>PD9 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 17:16          | R/W        | 0x1         | PD8_DRV<br>PD8 Multi-Driving Select<br>00: Level 0 01: Level 1                              |

|       |     |     |                                                                   |                            |
|-------|-----|-----|-------------------------------------------------------------------|----------------------------|
|       |     |     | 10: Level 2                                                       | 11: Level 3                |
| 15:14 | R/W | 0x1 | PD7_DRV<br>PD7 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 13:12 | R/W | 0x1 | PD6_DRV<br>PD6 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 11:10 | R/W | 0x1 | PD5_DRV<br>PD5 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 9:8   | R/W | 0x1 | PD4_DRV<br>PD4 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 7:6   | R/W | 0x1 | PD3_DRV<br>PD3 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 5:4   | R/W | 0x1 | PD2_DRV<br>PD2 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 3:2   | R/W | 0x1 | PD1_DRV<br>PD1 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 1:0   | R/W | 0x1 | PDO_DRV<br>PDO Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |

#### 10.6.5.19. 0x0084 PD Multi-Driving Register 1 (Default Value: 0x0000\_5555)

| Offset: 0x0084 |            |             | Register Name: PD_DRV1                                              |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:16          | /          | /           | /                                                                   |
| 15:14          | R/W        | 0x1         | PD23_DRV<br>PD23 Multi-Driving Select<br>00: Level 0<br>10: Level 2 |
| 13:12          | R/W        | 0x1         | PD22_DRV                                                            |

|       |     |     |                                                                                             |
|-------|-----|-----|---------------------------------------------------------------------------------------------|
|       |     |     | PD22 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3             |
| 11:10 | R/W | 0x1 | PD21_DRV<br>PD21 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 9:8   | R/W | 0x1 | PD20_DRV<br>PD20 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6   | R/W | 0x1 | PD19_DRV<br>PD19 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 5:4   | R/W | 0x1 | PD18_DRV<br>PD18 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 3:2   | R/W | 0x1 | PD17_DRV<br>PD17 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 1:0   | R/W | 0x1 | PD16_DRV<br>PD16 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 10.6.5.20. 0x0088 PD Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: PD_PULL0                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:30          | R/W        | 0x0         | PD15_PULL<br>PD15 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 29:28          | R/W        | 0x0         | PD14_PULL<br>PD14 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |
| 27:26          | R/W        | 0x0         | PD13_PULL<br>PD13 Pull-up/down Select<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

|       |     |     |                                                                                                                       |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------|
| 25:24 | R/W | 0x0 | PD12_PULL<br>PD12 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 23:22 | R/W | 0x0 | PD11_PULL<br>PD11 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 21:20 | R/W | 0x0 | PD10_PULL<br>PD10 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 19:18 | R/W | 0x0 | PD9_PULL<br>PD9 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 17:16 | R/W | 0x0 | PD8_PULL<br>PD8 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 15:14 | R/W | 0x0 | PD7_PULL<br>PD7 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 13:12 | R/W | 0x0 | PD6_PULL<br>PD6 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 11:10 | R/W | 0x0 | PD5_PULL<br>PD5 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 9:8   | R/W | 0x0 | PD4_PULL<br>PD4 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 7:6   | R/W | 0x0 | PD3_PULL<br>PD3 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 5:4   | R/W | 0x0 | PD2_PULL<br>PD2 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 3:2   | R/W | 0x0 | PD1_PULL                                                                                                              |

|     |     |     |                                                                                                                     |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------|
|     |     |     | PD1 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved             |
| 1:0 | R/W | 0x0 | PDO_PULL<br>PDO Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |

#### 10.6.5.21. 0x008C PD Pull Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: PD_PULL1                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                     |
| 15:14          | R/W        | 0x0         | PD23_PULL<br>PD23 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 13:12          | R/W        | 0x0         | PD22_PULL<br>PD22 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 11:10          | R/W        | 0x0         | PD21_PULL<br>PD21 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 9:8            | R/W        | 0x0         | PD20_PULL<br>PD20 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 7:6            | R/W        | 0x0         | PD19_PULL<br>PD19 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 5:4            | R/W        | 0x0         | PD18_PULL<br>PD18 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 3:2            | R/W        | 0x0         | PD17_PULL<br>PD17 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 1:0            | R/W        | 0x0         | PD16_PULL<br>PD16 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up                                    |

|  |  |  |               |              |
|--|--|--|---------------|--------------|
|  |  |  | 10: Pull-down | 11: Reserved |
|--|--|--|---------------|--------------|

#### 10.6.5.22. 0x0090 PE Configure Register 0 (Default Value: 0x7777\_7777)

| Offset: 0x0090 |            |             | Register Name: PE_CFG0                                                     |                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |                                                                  |
| 31             | /          | /           | /                                                                          |                                                                  |
| 30:28          | R/W        | 0x7         | PE7_SELECT<br>000:Input<br>010:CSI_SM_VS<br>100:I2S2_LRCK<br>110:PE_EINT7  | 001:Output<br>011:BIST_RESULT1<br>101:Reserved<br>111:IO Disable |
| 27             | /          | /           | /                                                                          |                                                                  |
| 26:24          | R/W        | 0x7         | PE6_SELECT<br>000:Input<br>010:Reserved<br>100:I2S2_BCLK<br>110:PE_EINT6   | 001:Output<br>011:BIST_RESULT0<br>101:Reserved<br>111:IO Disable |
| 23             | /          | /           | /                                                                          |                                                                  |
| 22:20          | R/W        | 0x7         | PE5_SELECT<br>000:Input<br>010:MIPI_MCLK1<br>100:I2S2_MCLK<br>110:PE_EINT5 | 001:Output<br>011:PLL_LOCK_DBG<br>101:LEDC<br>111:IO Disable     |
| 19             | /          | /           | /                                                                          |                                                                  |
| 18:16          | R/W        | 0x7         | PE4_SELECT<br>000:Input<br>010:TWI3_SDA<br>100:Reserved<br>110:PE_EINT4    | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable     |
| 15             | /          | /           | /                                                                          |                                                                  |
| 14:12          | R/W        | 0x7         | PE3_SELECT<br>000:Input<br>010:TWI3_SCK<br>100:Reserved<br>110:PE_EINT3    | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable     |
| 11             | /          | /           | /                                                                          |                                                                  |
| 10:8           | R/W        | 0x7         | PE2_SELECT<br>000:Input<br>010:TWI2_SDA<br>100:Reserved<br>110:PE_EINT2    | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable     |
| 7              | /          | /           | /                                                                          |                                                                  |

|     |     |     |                                                                                  |                                                              |
|-----|-----|-----|----------------------------------------------------------------------------------|--------------------------------------------------------------|
| 6:4 | R/W | 0x7 | <b>PE1_SELECT</b><br>000:Input<br>010:TWI2_SCK<br>100:Reserved<br>110:PE_EINT1   | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 3   | /   | /   | /                                                                                |                                                              |
| 2:0 | R/W | 0x7 | <b>PE0_SELECT</b><br>000:Input<br>010:MIPI_MCLK0<br>100:Reserved<br>110:PE_EINT0 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.23. 0x0094 PE Configure Register 1 (Default Value: 0x0000\_0077)

| Offset: 0x0094 |            |             | Register Name: PE_CFG1                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:7           | /          | /           | /                                                                                |
| 6:4            | R/W        | 0x7         | <b>PE9_SELECT</b><br>000:Input<br>010:Reserved<br>100:I2S2_DINO<br>110:PE_EINT9  |
| 3              | /          | /           | /                                                                                |
| 2:0            | R/W        | 0x7         | <b>PE8_SELECT</b><br>000:Input<br>010:Reserved<br>100:I2S2_DOUT0<br>110:PE_EINT8 |

#### 10.6.5.24. 0x00A0 PE Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: PE_DAT                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                             |
| 31:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                       |
| 9:0            | R/W        | 0x0         | <b>PE_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

**10.6.5.25. 0x00A4 PE Multi-Driving Register 0 (Default Value: 0x0005\_5555)**

| Offset: 0x00A4 |            |             | Register Name: PE_DRV0                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31:20          | /          | /           | /                                                                                                                |
| 19:18          | R/W        | 0x1         | PE9_DRV<br>PE9 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 17:16          | R/W        | 0x1         | PE8_DRV<br>PE8 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 15:14          | R/W        | 0x1         | PE7_DRV<br>PE7 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 13:12          | R/W        | 0x1         | PE6_DRV<br>PE6 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 11:10          | R/W        | 0x1         | PE5_DRV<br>PE5 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 9:8            | R/W        | 0x1         | PE4_DRV<br>PE4 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 7:6            | R/W        | 0x1         | PE3_DRV<br>PE3 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 5:4            | R/W        | 0x1         | PE2_DRV<br>PE2 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 3:2            | R/W        | 0x1         | PE1_DRV<br>PE1 Multi-Driving Select<br>00: Level 0--180Ω 01: Level 1--120Ω<br>10: Level 2--100Ω 11: Level 3--50Ω |
| 1:0            | R/W        | 0x1         | PE0_DRV<br>PE0 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |

**10.6.5.26. 0x00AC PE Pull Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x00AC |            |             | Register Name: PE_PULL0                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31:20          | /          | /           | /                                                                                                                   |
| 19:18          | R/W        | 0x0         | PE9_PULL<br>PE9 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 17:16          | R/W        | 0x0         | PE8_PULL<br>PE8 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 15:14          | R/W        | 0x0         | PE7_PULL<br>PE7 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 13:12          | R/W        | 0x0         | PE6_PULL<br>PE6 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 11:10          | R/W        | 0x0         | PE5_PULL<br>PE5 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 9:8            | R/W        | 0x0         | PE4_PULL<br>PE4 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 7:6            | R/W        | 0x0         | PE3_PULL<br>PE3 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 5:4            | R/W        | 0x0         | PE2_PULL<br>PE2 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 3:2            | R/W        | 0x0         | PE1_PULL<br>PE1 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 1:0            | R/W        | 0x0         | PE0_PULL<br>PE0 Pull-up/down Select                                                                                 |

|  |  |  |                                           |                             |
|--|--|--|-------------------------------------------|-----------------------------|
|  |  |  | 00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
|--|--|--|-------------------------------------------|-----------------------------|

#### 10.6.5.27. 0x00B4 PF Configure Register 0 (Default Value: 0x0777\_7777)

| Offset: 0x00B4 |            |             | Register Name: PF_CFG0                                                     |                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |                                                              |
| 31:27          | /          | /           | /                                                                          |                                                              |
| 26:24          | R/W        | 0x7         | PF6_SELECT<br>000:Input<br>010:Reserved<br>100:Reserved<br>110:PF_EINT6    | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 23             | /          | /           | /                                                                          |                                                              |
| 22:20          | R/W        | 0x7         | PF5_SELECT<br>000:Input<br>010:SDC0_D2<br>100:JTAG_CK_GPU<br>110:PF_EINT5  | 001:Output<br>011:JTAG_CK<br>101:Reserved<br>111:IO Disable  |
| 19             | /          | /           | /                                                                          |                                                              |
| 18:16          | R/W        | 0x7         | PF4_SELECT<br>000:Input<br>010:SDC0_D3<br>100:Reserved<br>110:PF_EINT4     | 001:Output<br>011:UART0_RX<br>101:Reserved<br>111:IO Disable |
| 15             | /          | /           | /                                                                          |                                                              |
| 14:12          | R/W        | 0x7         | PF3_SELECT<br>000:Input<br>010:SDC0_CMD<br>100:JTAG_DO_GPU<br>110:PF_EINT3 | 001:Output<br>011:JTAG_DO<br>101:Reserved<br>111:IO Disable  |
| 11             | /          | /           | /                                                                          |                                                              |
| 10:8           | R/W        | 0x7         | PF2_SELECT<br>000:Input<br>010:SDC0_CLK<br>100:Reserved<br>110:PF_EINT2    | 001:Output<br>011:UART0_TX<br>101:Reserved<br>111:IO Disable |
| 7              | /          | /           | /                                                                          |                                                              |
| 6:4            | R/W        | 0x7         | PF1_SELECT<br>000:Input<br>010:SDC0_D0<br>100:JTAG_DI_GPU<br>110:PF_EINT1  | 001:Output<br>011:JTAG_DI<br>101:Reserved<br>111:IO Disable  |

|     |     |     |                                                                                                                                          |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | /   | /   | /                                                                                                                                        |
| 2:0 | R/W | 0x7 | PFO_SELECT<br>000:Input<br>010:SDCO_D1<br>100:JTAG_MS_GPU<br>110:PF_EINT0<br>001:Output<br>011:JTAG_MS<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.28. 0x00C4 PF Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: PF_DAT                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                             |
| 31:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                       |
| 6:0            | R/W        | 0           | <b>PF_DAT</b><br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.29. 0x00C8 PF Multi-Driving Register 0 (Default Value: 0x0000\_1555)

| Offset: 0x00C8 |            |             | Register Name: PF_DRV0                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 31:14          | /          | /           | /                                                                                                                                      |
| 13:12          | R/W        | 0x1         | <b>PF6_DRV</b><br>PF6 Multi-Driving Select<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
| 11:10          | R/W        | 0x1         | <b>PF5_DRV</b><br>PF5 Multi-Driving Select<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
| 9:8            | R/W        | 0x1         | <b>PF4_DRV</b><br>PF4 Multi-Driving Select<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
| 7:6            | R/W        | 0x1         | <b>PF3_DRV</b><br>PF3 Multi-Driving Select<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
| 5:4            | R/W        | 0x1         | <b>PF2_DRV</b><br>PF2 Multi-Driving Select                                                                                             |

|     |     |     |                                                                   |                                       |
|-----|-----|-----|-------------------------------------------------------------------|---------------------------------------|
|     |     |     | 00: Level 0--180Ω<br>10: Level 2--100Ω                            | 01: Level 1--120Ω<br>11: Level 3--50Ω |
| 3:2 | R/W | 0x1 | PF1_DRV<br>PF1 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3            |
| 1:0 | R/W | 0x1 | PF0_DRV<br>PF0 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3            |

#### 10.6.5.30. 0x00D0 PF Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: PF_PULL0                                                          |                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |                             |
| 31:14          | /          | /           | /                                                                                |                             |
| 13:12          | R/W        | 0x0         | PF6_PULL<br>PF6 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 11:10          | R/W        | 0x0         | PF5_PULL<br>PF5 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 9:8            | R/W        | 0x0         | PF4_PULL<br>PF4 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 7:6            | R/W        | 0x0         | PF3_PULL<br>PF3 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 5:4            | R/W        | 0x0         | PF2_PULL<br>PF2 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 3:2            | R/W        | 0x0         | PF1_PULL<br>PF1 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 1:0            | R/W        | 0x0         | PF0_PULL<br>PF0 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |

**10.6.5.31. 0x00D8 PG Configure Register 0 (Default Value: 0x7777\_7777)**

| Offset: 0x00D8 |            |             | Register Name: PG_CFG0                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31             | /          | /           | /                                                                                                                           |
| 30:28          | R/W        | 0x7         | PG7_SELECT<br>000:Input 001:Output<br>010:UART1_RX 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT7 111:IO Disable |
| 27             | /          | /           | /                                                                                                                           |
| 26:24          | R/W        | 0x7         | PG6_SELECT<br>000:Input 001:Output<br>010:UART1_TX 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT6 111:IO Disable |
| 23             | /          | /           | /                                                                                                                           |
| 22:20          | R/W        | 0x7         | PG5_SELECT<br>000:Input 001:Output<br>010:SDC1_D3 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT5 111:IO Disable  |
| 19             | /          | /           | /                                                                                                                           |
| 18:16          | R/W        | 0x7         | PG4_SELECT<br>000:Input 001:Output<br>010:SDC1_D2 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT4 111:IO Disable  |
| 15             | /          | /           | /                                                                                                                           |
| 14:12          | R/W        | 0x7         | PG3_SELECT<br>000:Input 001:Output<br>010:SDC1_D1 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT3 111:IO Disable  |
| 11             | /          | /           | /                                                                                                                           |
| 10:8           | R/W        | 0x7         | PG2_SELECT<br>000:Input 001:Output<br>010:SDC1_D0 011:Reserved<br>100:Reserved 101:Reserved<br>110:PG_EINT2 111:IO Disable  |
| 7              | /          | /           | /                                                                                                                           |
| 6:4            | R/W        | 0x7         | PG1_SELECT                                                                                                                  |

|     |     |     |                                                                         |                                                              |
|-----|-----|-----|-------------------------------------------------------------------------|--------------------------------------------------------------|
|     |     |     | 000:Input<br>010:SDC1_CMD<br>100:Reserved<br>110:PG_EINT1               | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 3   | /   | /   | /                                                                       |                                                              |
| 2:0 | R/W | 0x7 | PG0_SELECT<br>000:Input<br>010:SDC1_CLK<br>100:Reserved<br>110:PG_EINT0 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.32. 0x00DC PG Configure Register 1 (Default Value: 0x0077\_7777)

| Offset: 0x00DC |            |             | Register Name: PG_CFG1                                                      |                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |                                                                |
| 31:23          | /          | /           | /                                                                           |                                                                |
| 22:20          | R/W        | 0x7         | PG13_SELECT<br>000:Input<br>010:Reserved<br>100:I2S1_DOUT1<br>110:PG_EINT13 | 001:Output<br>011:I2S1_DINO<br>101:Reserved<br>111:IO Disable  |
| 19             | /          | /           | /                                                                           |                                                                |
| 18:16          | R/W        | 0x7         | PG12_SELECT<br>000:Input<br>010:Reserved<br>100:I2S1_DIN1<br>110:PG_EINT12  | 001:Output<br>011:I2S1_DOUT0<br>101:Reserved<br>111:IO Disable |
| 15             | /          | /           | /                                                                           |                                                                |
| 14:12          | R/W        | 0x7         | PG11_SELECT<br>000:Input<br>010:Reserved<br>100:Reserved<br>110:PG_EINT11   | 001:Output<br>011:I2S1_LRCK<br>101:Reserved<br>111:IO Disable  |
| 11             | /          | /           | /                                                                           |                                                                |
| 10:8           | R/W        | 0x7         | PG10_SELECT<br>000:Input<br>010:Reserved<br>100:Reserved<br>110:PG_EINT10   | 001:Output<br>011:I2S1_BCLK<br>101:Reserved<br>111:IO Disable  |
| 7              | /          | /           | /                                                                           |                                                                |
| 6:4            | R/W        | 0x7         | PG9_SELECT<br>000:Input<br>010:UART1_CTS                                    | 001:Output<br>011:I2S1_MCLK                                    |

|     |     |     |                                                                          |                                                              |
|-----|-----|-----|--------------------------------------------------------------------------|--------------------------------------------------------------|
|     |     |     | 100:Reserved<br>110:PG_EINT9                                             | 101:Reserved<br>111:IO Disable                               |
| 3   | /   | /   | /                                                                        |                                                              |
| 2:0 | R/W | 0x7 | PG8_SELECT<br>000:Input<br>010:UART1_RTS<br>100:Reserved<br>110:PG_EINT8 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |

#### 10.6.5.33. 0x00E8 PG Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00E8 |            |             | Register Name: PG_DAT                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                      |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                |
| 13:0           | R/W        | 0x0         | PG_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.34. 0x00EC PG Multi-Driving Register 0 (Default Value: 0x0555\_5555)

| Offset: 0x00EC |            |             | Register Name: PG_DRV0                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:28          | /          | /           | /                                                                                           |
| 27:26          | R/W        | 0x1         | PG13_DRV<br>PG13 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 25:24          | R/W        | 0x1         | PG12_DRV<br>PG12 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | R/W        | 0x1         | PG11_DRV<br>PG11 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 21:20          | R/W        | 0x1         | PG10_DRV<br>PG10 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

|       |     |     |                                                                                                                  |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------|
| 19:18 | R/W | 0x1 | PG9_DRV<br>PG9 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 17:16 | R/W | 0x1 | PG8_DRV<br>PG8 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 15:14 | R/W | 0x1 | PG7_DRV<br>PG7 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 13:12 | R/W | 0x1 | PG6_DRV<br>PG6 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 11:10 | R/W | 0x1 | PG5_DRV<br>PG5 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 9:8   | R/W | 0x1 | PG4_DRV<br>PG4 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 7:6   | R/W | 0x1 | PG3_DRV<br>PG3 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 5:4   | R/W | 0x1 | PG2_DRV<br>PG2 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 3:2   | R/W | 0x1 | PG1_DRV<br>PG1 Multi-Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3                        |
| 1:0   | R/W | 0x1 | PG0_DRV<br>PG0 Multi-Driving Select<br>00: Level 0--180Ω 01: Level 1--120Ω<br>10: Level 2--100Ω 11: Level 3--50Ω |

#### 10.6.5.35. 0x00F4 PG Pull Register 0 (Default Value: 0x0000\_0554)

| Offset: 0x00F4 | Register Name: PG_PULL0 |
|----------------|-------------------------|
|----------------|-------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                           |
|-------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| 31:28 | /          | /           | /                                                                                                                     |
| 27:26 | R/W        | 0x0         | PG13_PULL<br>PG13 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 25:24 | R/W        | 0x0         | PG12_PULL<br>PG12 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 23:22 | R/W        | 0x0         | PG11_PULL<br>PG11 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 21:20 | R/W        | 0x0         | PG10_PULL<br>PG10 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 19:18 | R/W        | 0x0         | PG9_PULL<br>PG9 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 17:16 | R/W        | 0x0         | PG8_PULL<br>PG8 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 15:14 | R/W        | 0x0         | PG7_PULL<br>PG7 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 13:12 | R/W        | 0x0         | PG6_PULL<br>PG6 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 11:10 | R/W        | 0x1         | PG5_PULL<br>PG5 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 9:8   | R/W        | 0x1         | PG4_PULL<br>PG4 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 7:6   | R/W        | 0x1         | PG3_PULL<br>PG3 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up                                      |

|     |     |     |                                                                                  |                             |
|-----|-----|-----|----------------------------------------------------------------------------------|-----------------------------|
|     |     |     | 10: Pull-down                                                                    | 11: Reserved                |
| 5:4 | R/W | 0x1 | PG2_PULL<br>PG2 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 3:2 | R/W | 0x1 | PG1_PULL<br>PG1 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 1:0 | R/W | 0x0 | PG0_PULL<br>PG0 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |

#### 10.6.5.36. 0x00FC PH Configure Register 0 (Default Value: 0x7777\_7777)

| Offset: 0x00FC |            |             | Register Name: PH_CFG0                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31             | /          | /           | /                                                                                                                                                       |
| 30:28          | R/W        | 0x7         | PH7_SELECT<br>000:Input<br>010:UART3_CTS<br>100:OWA_OUT<br>110:PH_EINT7<br>001:Output<br>011:SPI1_MISO<br>101:RGMII0_TXCTL/RMII0_TXEN<br>111:IO Disable |
| 27             | /          | /           | /                                                                                                                                                       |
| 26:24          | R/W        | 0x7         | PH6_SELECT<br>000:Input<br>010:UART3 RTS<br>100:Reserved<br>110:PH_EINT6<br>001:Output<br>011:SPI1_MOSI<br>101:RGMII0_RXCK/RMII0_RXCK<br>111:IO Disable |
| 23             | /          | /           | /                                                                                                                                                       |
| 22:20          | R/W        | 0x7         | PH5_SELECT<br>000:Input<br>010:UART3_RX<br>100:LEDC<br>110:PH_EINT5<br>001:Output<br>011:SPI1_CLK<br>101:RGMII0_RXD0/RMII_TXD0<br>111:IO Disable        |
| 19             | /          | /           | /                                                                                                                                                       |
| 18:16          | R/W        | 0x7         | PH4_SELECT<br>000:Input<br>010:UART3_TX<br>100:CPU_CUR_W<br>110:PH_EINT4<br>001:Output<br>011:SPI1_CS<br>101:RGMII0_RXD1/RMII0_RXD1<br>111:IO Disable   |
| 15             | /          | /           | /                                                                                                                                                       |

|       |     |     |                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------|
|       |     |     | PH3_SELECT<br>000:Input<br>010:TWI1_SDA<br>100:Reserved<br>110:PH_EINT3    |
| 14:12 | R/W | 0x7 | 001:Output<br>011:CIR_OUT<br>101:RGMII0_CLKIN/RMII0_RXER<br>111:IO Disable |
| 11    | /   | /   | /                                                                          |
| 10:8  | R/W | 0x7 | PH2_SELECT<br>000:Input<br>010:TWI1_SCK<br>100:Reserved<br>110:PH_EINT2    |
| 7     | /   | /   | /                                                                          |
| 6:4   | R/W | 0x7 | PH1_SELECT<br>000:Input<br>010:TWI0_SDA<br>100:Reserved<br>110:PH_EINT1    |
| 3     | /   | /   | /                                                                          |
| 2:0   | R/W | 0x7 | PH0_SELECT<br>000:Input<br>010:TWI0_SCK<br>100:Reserved<br>110:PH_EINT0    |

#### 10.6.5.37. 0x0100 PH Configure Register 1 (Default Value: 0x7777\_7777)

| Offset: 0x0100 |            | Register Name: PH_CFG1 |                                                                            |
|----------------|------------|------------------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex            | Description                                                                |
| 31             | /          | /                      | /                                                                          |
| 30:28          | R/W        | 0x7                    | PH15_SELECT<br>000:Input<br>010:Reserved<br>100:I2S3_LRCK<br>110:PH_EINT15 |
| 27             | /          | /                      | /                                                                          |
| 26:24          | R/W        | 0x7                    | PH14_SELECT<br>000:Input<br>010:Reserved<br>100:I2S3_BCLK<br>110:PH_EINT14 |
| 23             | /          | /                      | /                                                                          |
| 22:20          | R/W        | 0x7                    | PH13_SELECT<br>000:Input<br>001:Output                                     |

|       |     |     |                                                                               |                                                                |
|-------|-----|-----|-------------------------------------------------------------------------------|----------------------------------------------------------------|
|       |     |     | 010:Reserved<br>100:I2S3_MCLK<br>110:PH_EINT13                                | 011:TWI3_SDA<br>101:EPHY0_25<br>111:IO Disable                 |
| 19    | /   | /   | /                                                                             |                                                                |
| 18:16 | R/W | 0x7 | PH12_SELECT<br>000:Input<br>010:DMIC_DATA3<br>100:I2S2_DINO<br>110:PH_EINT12  | 001:Output<br>011:TWI3_SCK<br>101:I2S2_DOUT1<br>111:IO Disable |
| 15    | /   | /   | /                                                                             |                                                                |
| 14:12 | R/W | 0x7 | PH11_SELECT<br>000:Input<br>010:DMIC_DATA2<br>100:I2S2_DOUT0<br>110:PH_EINT11 | 001:Output<br>011:SPI2_MISO<br>101:I2S2_DIN1<br>111:IO Disable |
| 11    | /   | /   | /                                                                             |                                                                |
| 10:8  | R/W | 0x7 | PH10_SELECT<br>000:Input<br>010:DMIC_DATA1<br>100:I2S2_LRCK<br>110:PH_EINT10  | 001:Output<br>011:SPI2_MOSI<br>101:MDIO0<br>111:IO Disable     |
| 7     | /   | /   | /                                                                             |                                                                |
| 6:4   | R/W | 0x7 | PH9_SELECT<br>000:Input<br>010:DMIC_DATA0<br>100:I2S2_BCLK<br>110:PH_EINT9    | 001:Output<br>011:SPI2_CLK<br>101:MDC0<br>111:IO Disable       |
| 3     | /   | /   | /                                                                             |                                                                |
| 2:0   | R/W | 0x7 | PH8_SELECT<br>000:Input<br>010:DMIC_CLK<br>100:I2S2_MCLK<br>110:PH_EINT8      | 001:Output<br>011:SPI2_CS<br>101:I2S2_DIN2<br>111:IO Disable   |

#### 10.6.5.38. 0x0104 PH Configure Register 2 (Default Value: 0x0000\_7777)

| Offset: 0x0104 |            |             | Register Name: PH_CFG2                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:15          | /          | /           | /                                                                                                   |
| 14:12          | R/W        | 0x7         | PH19_SELECT<br>000:Input<br>010:CIR_IN<br>100:I2S3_DIN3<br>001:Output<br>011:I2S3_DOUT3<br>101:LEDC |

|      |     |     |                                                                            |                                                                              |
|------|-----|-----|----------------------------------------------------------------------------|------------------------------------------------------------------------------|
|      |     |     | 110:PH_EINT19                                                              | 111:IO Disable                                                               |
| 11   | /   | /   | /                                                                          |                                                                              |
| 10:8 | R/W | 0x7 | PH18_SELECT<br>000:Input<br>010:CIR_OUT<br>100:I2S3_DIN2<br>110:PH_EINT18  | 001:Output<br>011:I2S3_DOUT2<br>101:RGMII0_RXD2/RMII0_NULL<br>111:IO Disable |
| 7    | /   | /   | /                                                                          |                                                                              |
| 6:4  | R/W | 0x7 | PH17_SELECT<br>000:Input<br>010:Reserved<br>100:I2S3_DIN0<br>110:PH_EINT17 | 001:Output<br>011:I2S3_DOUT1<br>101:RGMII0_RXD3/RMII0_NULL<br>111:IO Disable |
| 3    | /   | /   | /                                                                          |                                                                              |
| 2:0  | R/W | 0x7 | PH16_SELECT<br>000:Input<br>010:Reserved<br>100:I2S3_DIN1<br>110:PH_EINT16 | 001:Output<br>011:I2S3_DOUT0<br>101:RGMII0_RXCK/RMII0_NULL<br>111:IO Disable |

#### 10.6.5.39. 0x010C PH Data Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: PH_DAT                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                      |
| 31:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                |
| 19:0           | R/W        | 0x0         | PH_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 10.6.5.40. 0x0110 PH Multi-Driving Register 0 (Default Value: 0x5555\_5555)

| Offset: 0x0110 |            |             | Register Name: PH_DRV0                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:30          | R/W        | 0x1         | PH15_DRV<br>PH15 Multi_Driving Select<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
| 29:28          | R/W        | 0x1         | PH14_DRV<br>PH14 Multi_Driving Select                                                                                             |

|       |     |     |                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------|
|       |     |     | 00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3                                          |
| 27:26 | R/W | 0x1 | PH13_DRV<br>PH13 Multi_Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3 |
| 25:24 | R/W | 0x1 | PH12_DRV<br>PH12 Multi_Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3 |
| 23:22 | R/W | 0x1 | PH11_DRV<br>PH11 Multi_Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3 |
| 21:20 | R/W | 0x1 | PH10_DRV<br>PH10 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3 |
| 19:18 | R/W | 0x1 | PH9_DRV<br>PH9 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 17:16 | R/W | 0x1 | PH8_DRV<br>PH8 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 15:14 | R/W | 0x1 | PH7_DRV<br>PH7 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 13:12 | R/W | 0x1 | PH6_DRV<br>PH6 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 11:10 | R/W | 0x1 | PH5_DRV<br>PH5 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 9:8   | R/W | 0x1 | PH4_DRV<br>PH4 Multi-Driving Select<br>00: Level 0<br>10: Level 2<br>01: Level 1<br>11: Level 3   |
| 7:6   | R/W | 0x1 | PH3_DRV<br>PH3 Multi-Driving Select<br>00: Level 0<br>01: Level 1                                 |

|     |     |     |                                                                   |                            |
|-----|-----|-----|-------------------------------------------------------------------|----------------------------|
|     |     |     | 10: Level 2                                                       | 11: Level 3                |
| 5:4 | R/W | 0x1 | PH2_DRV<br>PH2 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 3:2 | R/W | 0x1 | PH1_DRV<br>PH1 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 1:0 | R/W | 0x1 | PH0_DRV<br>PH0 Multi-Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |

#### 10.6.5.41. 0x0114 PH Multi-Driving Register 0 (Default Value: 0x0000\_0055)

| Offset: 0x0114 |            |             | Register Name: PH_DRV1                                              |                            |
|----------------|------------|-------------|---------------------------------------------------------------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |                            |
| 31:8           | /          | /           | /                                                                   |                            |
| 7:6            | R/W        | 0x1         | PH19_DRV<br>PH19 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 5:4            | R/W        | 0x1         | PH18_DRV<br>PH18 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 3:2            | R/W        | 0x1         | PH17_DRV<br>PH17 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |
| 1:0            | R/W        | 0x1         | PH16_DRV<br>PH16 Multi_Driving Select<br>00: Level 0<br>10: Level 2 | 01: Level 1<br>11: Level 3 |

#### 10.6.5.42. 0x0118 PH Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0118 |            |             | Register Name: PH_PULL0               |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:30          | R/W        | 0x0         | PH15_PULL<br>PH15 Pull_up/down Select |

|       |     |     |                                                                                                                       |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------|
|       |     |     | 00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved                                          |
| 29:28 | R/W | 0x0 | PH14_PULL<br>PH14 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 27:26 | R/W | 0x0 | PH13_PULL<br>PH13 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 25:24 | R/W | 0x0 | PH12_PULL<br>PH12 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 23:22 | R/W | 0x0 | PH11_PULL<br>PH11 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 21:20 | R/W | 0x0 | PH10_PULL<br>PH10 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved |
| 19:18 | R/W | 0x0 | PH9_PULL<br>PH9 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 17:16 | R/W | 0x0 | PH8_PULL<br>PH8 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 15:14 | R/W | 0x0 | PH7_PULL<br>PH7 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 13:12 | R/W | 0x0 | PH6_PULL<br>PH6 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 11:10 | R/W | 0x0 | PH5_PULL<br>PH5 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up<br>10: Pull-down      11: Reserved   |
| 9:8   | R/W | 0x0 | PH4_PULL<br>PH4 Pull-up/down Select<br>00: Pull-up/down disable      01: Pull-up                                      |

|     |     |     |                                                                                  |                             |
|-----|-----|-----|----------------------------------------------------------------------------------|-----------------------------|
|     |     |     | 10: Pull-down                                                                    | 11: Reserved                |
| 7:6 | R/W | 0x1 | PH3_PULL<br>PH3 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 5:4 | R/W | 0x1 | PH2_PULL<br>PH2 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 3:2 | R/W | 0x0 | PH1_PULL<br>PH1 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |
| 1:0 | R/W | 0x0 | PH0_PULL<br>PH0 Pull-up/down Select<br>00: Pull-up/down disable<br>10: Pull-down | 01: Pull-up<br>11: Reserved |

#### 10.6.5.43. 0x011C PH Pull Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x011C |            |             | Register Name: PH_PULL1                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:8           | /          | /           | /                                                                                  |
| 7:6            | R/W        | 0x0         | PH19_PULL<br>PH19 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down |
| 5:4            | R/W        | 0x0         | PH18_PULL<br>PH18 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down |
| 3:2            | R/W        | 0x0         | PH17_PULL<br>PH17 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down |
| 1:0            | R/W        | 0x0         | PH16_PULL<br>PH16 Pull_up/down Select<br>00: Pull_up/down disable<br>10: Pull_down |

**10.6.5.44. 0x0220 PB External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x0220 |            |             | Register Name: PB_EINT_CFG0                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG                                                                                                                                                                     |

|     |     |     |                                                                                                                                                                               |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved              |
| 7:4 | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 3:0 | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |

#### 10.6.5.45. 0x0224 PB External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0224 |            |             | Register Name: PB_EINT_CFG1                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31:12          | /          | /           | /                                                                                                                                                                               |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)                       |

|     |     |     |                                                                                                                                                                               |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | Others: Reserved                                                                                                                                                              |
| 3:0 | R/W | 0x0 | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |

**10.6.5.46. 0x0230 PB External Interrupt Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x0230 |            |             | Register Name: PB_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:11          | /          | /           | /                                                              |
| 10             | R/W        | 0x0         | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8              | R/W        | 0x0         | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3              | R/W        | 0x0         | EINT3_CTL                                                      |

|   |     |     |                                                              |
|---|-----|-----|--------------------------------------------------------------|
|   |     |     | External INT3 Enable<br>0: Disable<br>1: Enable              |
| 2 | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1 | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 10.6.5.47. 0x0234 PB External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: PB_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:11          | /          | /           | /                                                                                                        |
| 10             | R/W        | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W        | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W        | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7              | R/W        | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 6              | R/W        | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending                                           |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
|   |     |     | 1: IRQ pending<br>Write '1' to clear                                                                   |
| 5 | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4 | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3 | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.48. 0x0218 PB External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0218 |            |             | Register Name: PB_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select                                                     |

|  |  |  |                                        |
|--|--|--|----------------------------------------|
|  |  |  | 0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M) |
|--|--|--|----------------------------------------|

**10.6.5.49. 0x0240 PC External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x0240 |            |             | Register Name: PC_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level                                                                               |

|      |     |     |                                                                                                                                                                              |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                   |
| 11:8 | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4  | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0  | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.50. 0x0244 PC External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0244 |            |             | Register Name: PC_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT15_CFG<br>External INT15 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT14_CFG<br>External INT14 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge                                                                                                  |

|       |     |     |                                                                                                                                                                                |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                  |
| 23:20 | R/W | 0x0 | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W | 0x0 | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |
| 3:0   | R/W | 0x0 | EINT8_CFG                                                                                                                                                                      |

|  |  |  |                                                                                                                                                                 |
|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.6.5.51. 0x0248 PC External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: PC_EINT_CFG2                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:4           | /          | /           | /                                                                                                                                                                                      |
| 3:0            | R/W        | 0x0         | <b>EINT16_CFG</b><br>External INT16 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |

#### 10.6.5.52. 0x0250 PC External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0250 |            |             | Register Name: PC_EINT_CTL                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:17          | /          | /           | /                                                                     |
| 16             | R/W        | 0x0         | <b>EINT16_CTL</b><br>External INT16 Enable<br>0: Disable<br>1: Enable |
| 15             | R/W        | 0x0         | <b>EINT15_CTL</b><br>External INT15 Enable<br>0: Disable<br>1: Enable |
| 14             | R/W        | 0x0         | <b>EINT14_CTL</b><br>External INT14 Enable<br>0: Disable<br>1: Enable |
| 13             | R/W        | 0x0         | <b>EINT13_CTL</b><br>External INT13 Enable<br>0: Disable              |

|    |     |     |                                                                |
|----|-----|-----|----------------------------------------------------------------|
|    |     |     | 1: Enable                                                      |
| 12 | R/W | 0x0 | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11 | R/W | 0x0 | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10 | R/W | 0x0 | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9  | R/W | 0x0 | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8  | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7  | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6  | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5  | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4  | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3  | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable   |
| 2  | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable   |

|   |     |     |                                                              |
|---|-----|-----|--------------------------------------------------------------|
| 1 | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 10.6.5.53. 0x0254 PC External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0254 |            |             | Register Name: PC_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:17          | /          | /           | /                                                                                                        |
| 16             | R/W        | 0x0         | EINT16_STATUS<br>External INT16 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 15             | R/W        | 0x0         | EINT15_STATUS<br>External INT15 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 14             | R/W        | 0x0         | EINT14_STATUS<br>External INT14 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 13             | R/W        | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W        | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W        | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

|    |     |     |                                                                                                          |
|----|-----|-----|----------------------------------------------------------------------------------------------------------|
| 10 | R/W | 0x0 | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9  | R/W | 0x0 | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8  | R/W | 0x0 | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7  | R/W | 0x0 | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 6  | R/W | 0x0 | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 5  | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 4  | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 3  | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 2  | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.54. 0x0258 PC External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0258 |            |             | Register Name: PC_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.5.55. 0x0260 PD External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0260 |            |             | Register Name: PD_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level                                                             |

|       |     |     |                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                                     |
| 23:20 | R/W | 0x0 | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W | 0x0 | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0   | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge                                                                                                                        |

|  |  |  |                                                                                                                     |
|--|--|--|---------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
|--|--|--|---------------------------------------------------------------------------------------------------------------------|

**10.6.5.56. 0x0264 PD External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0264 |            |             | Register Name: PD_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT15_CFG<br>External INT15 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT14_CFG<br>External INT14 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode                                                                                                                                              |

|      |     |     |                                                                                                                                                                                |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                      |
| 11:8 | R/W | 0x0 | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4  | R/W | 0x0 | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |
| 3:0  | R/W | 0x0 | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |

#### 10.6.5.57. 0x0268 PD External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0268 |            |             | Register Name: PD_EINT_CFG2                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT23_CFG<br>External INT23 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT22_CFG                                                                                                                                                                     |

|       |     |     |                                                                                                                                                                                |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | External INT22 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved               |
| 23:20 | R/W | 0x0 | EINT21_CFG<br>External INT21 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W | 0x0 | EINT20_CFG<br>External INT20 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT19_CFG<br>External INT19 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT18_CFG<br>External INT18 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT17_CFG<br>External INT17 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level                                                             |

|     |     |     |                                                                                                                                                                                |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                                       |
| 3:0 | R/W | 0x0 | EINT16_CFG<br>External INT16 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.58. 0x0270 PD External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0270 |            |             | Register Name: PD_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:24          | /          | /           | /                                                              |
| 23             | R/W        | 0x0         | EINT23_CTL<br>External INT23 Enable<br>0: Disable<br>1: Enable |
| 22             | R/W        | 0x0         | EINT22_CTL<br>External INT22 Enable<br>0: Disable<br>1: Enable |
| 21             | R/W        | 0x0         | EINT21_CTL<br>External INT21 Enable<br>0: Disable<br>1: Enable |
| 20             | R/W        | 0x0         | EINT20_CTL<br>External INT20 Enable<br>0: Disable<br>1: Enable |
| 19             | R/W        | 0x0         | EINT19_CTL<br>External INT19 Enable<br>0: Disable<br>1: Enable |
| 18             | R/W        | 0x0         | EINT18_CTL<br>External INT18 Enable<br>0: Disable<br>1: Enable |
| 17             | R/W        | 0x0         | EINT17_CTL<br>External INT17 Enable<br>0: Disable<br>1: Enable |

|    |     |     |                                                                |
|----|-----|-----|----------------------------------------------------------------|
| 16 | R/W | 0x0 | EINT16_CTL<br>External INT16 Enable<br>0: Disable<br>1: Enable |
| 15 | R/W | 0x0 | EINT15_CTL<br>External INT15 Enable<br>0: Disable<br>1: Enable |
| 14 | R/W | 0x0 | EINT14_CTL<br>External INT14 Enable<br>0: Disable<br>1: Enable |
| 13 | R/W | 0x0 | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |
| 12 | R/W | 0x0 | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11 | R/W | 0x0 | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10 | R/W | 0x0 | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9  | R/W | 0x0 | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8  | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7  | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6  | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5  | R/W | 0x0 | EINT5_CTL                                                      |

|   |     |     |                                                              |
|---|-----|-----|--------------------------------------------------------------|
|   |     |     | External INT5 Enable<br>0: Disable<br>1: Enable              |
| 4 | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3 | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2 | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1 | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 10.6.5.59. 0x0274 PD External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0274 |            |             | Register Name: PD_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:24          | /          | /           | /                                                                                                        |
| 23             | R/W        | 0x0         | EINT23_STATUS<br>External INT23 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 22             | R/W        | 0x0         | EINT22_STATUS<br>External INT22 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 21             | R/W        | 0x0         | EINT21_STATUS<br>External INT21 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

|    |     |     |                                                                                                          |
|----|-----|-----|----------------------------------------------------------------------------------------------------------|
| 20 | R/W | 0x0 | EINT20_STATUS<br>External INT20 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 19 | R/W | 0x0 | EINT19_STATUS<br>External INT19 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 18 | R/W | 0x0 | EINT18_STATUS<br>External INT18 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 17 | R/W | 0x0 | EINT17_STATUS<br>External INT17 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 16 | R/W | 0x0 | EINT16_STATUS<br>External INT16 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 15 | R/W | 0x0 | EINT15_STATUS<br>External INT15 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 14 | R/W | 0x0 | EINT14_STATUS<br>External INT14 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 13 | R/W | 0x0 | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12 | R/W | 0x0 | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

|    |     |     |                                                                                                          |
|----|-----|-----|----------------------------------------------------------------------------------------------------------|
| 11 | R/W | 0x0 | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10 | R/W | 0x0 | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9  | R/W | 0x0 | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8  | R/W | 0x0 | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7  | R/W | 0x0 | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 6  | R/W | 0x0 | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 5  | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 4  | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 3  | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INTO Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.60. 0x0278 PD External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: PD_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.5.61. 0x0280 PE External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0280 |            |             | Register Name: PD_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

|       |     |     |                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24 | R/W | 0x0 | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20 | R/W | 0x0 | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W | 0x0 | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level                                                                               |

|     |     |     |                                                                                                                                                                              |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                   |
| 3:0 | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.62. 0x0284 PE External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0284 |            |             | Register Name: PE_EINT_CFG1                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:8           | /          | /           | /                                                                                                                                                                            |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.63. 0x0290 PE External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0290 |            |             | Register Name: PE_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:10          | /          | /           | /                                                            |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable |

|   |     |     |                                                              |
|---|-----|-----|--------------------------------------------------------------|
| 8 | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable |
| 7 | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable |
| 6 | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable |
| 5 | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4 | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3 | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2 | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1 | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 10.6.5.64. 0x0294 PE External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0294 |            |             | Register Name: PE_EINT_STATUS             |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:10          | /          | /           | /                                         |
| 9              | R/W        | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
|   |     |     | 0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                                              |
| 8 | R/W | 0x0 | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 7 | R/W | 0x0 | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 6 | R/W | 0x0 | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5 | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4 | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3 | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit                                                              |

|  |  |  |                                                           |
|--|--|--|-----------------------------------------------------------|
|  |  |  | 0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
|--|--|--|-----------------------------------------------------------|

#### 10.6.5.65. 0x0298 PE External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0298 |            |             | Register Name: PE_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.5.66. 0x02A0 PF External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x02A0 |            |             | Register Name: PF_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | /          | /           | /                                                                                                                                                                            |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge                                                                                                                        |

|       |     |     |                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                          |
| 15:12 | R/W | 0x0 | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0   | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.67. 0x02B0 PF External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x02B0 |            |             | Register Name: PF_EINT_CTL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:7           | /          | /           | /                          |
| 6              | R/W        | 0x0         | EINT6_CTL                  |

|   |     |     |                                                              |
|---|-----|-----|--------------------------------------------------------------|
|   |     |     | External INT6 Enable<br>0: Disable<br>1: Enable              |
| 5 | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4 | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3 | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2 | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1 | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 10.6.5.68. 0x02B4 PF External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x02B4 |            |             | Register Name: PF_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:7           | /          | /           | /                                                                                                      |
| 6              | R/W        | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W        | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W        | 0x0         | EINT4_STATUS                                                                                           |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
|   |     |     | External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                 |
| 3 | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.69. 0x02B8 PF External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x02B8 |            |             | Register Name: PF_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.5.70. 0x02C0 PG External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

|                |                             |
|----------------|-----------------------------|
| Offset: 0x02C0 | Register Name: PG_EINT_CFG0 |
|----------------|-----------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                  |
|-------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28 | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24 | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20 | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge                                                                                                  |

|     |     |     |                                                                                                                                                                              |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                |
| 7:4 | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0 | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.71. 0x02C4 PG External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x02C4 |            |             | Register Name: PG_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:24          | /          | /           | /                                                                                                                                                                              |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode                                                                                                                                              |

|      |     |     |                                                                                                                                                                                |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                      |
| 11:8 | R/W | 0x0 | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4  | R/W | 0x0 | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |
| 3:0  | R/W | 0x0 | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |

#### 10.6.5.72. 0x02D0 PG External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x02D0 |            |             | Register Name: PG_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:14          | /          | /           | /                                                              |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |

|    |     |     |                                                                |
|----|-----|-----|----------------------------------------------------------------|
| 11 | R/W | 0x0 | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10 | R/W | 0x0 | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9  | R/W | 0x0 | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8  | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7  | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6  | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5  | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4  | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3  | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable   |
| 2  | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable   |
| 1  | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable   |
| 0  | R/W | 0x0 | EINT0_CTL                                                      |

|  |  |  |                                                 |
|--|--|--|-------------------------------------------------|
|  |  |  | External INTO Enable<br>0: Disable<br>1: Enable |
|--|--|--|-------------------------------------------------|

**10.6.5.73. 0x02D4 PG External Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x02D4 |            |             | Register Name: PG_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:14          | /          | /           | /                                                                                                        |
| 13             | R/W        | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W        | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W        | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10             | R/W        | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W        | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W        | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7              | R/W        | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
| 6 | R/W | 0x0 | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5 | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4 | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3 | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INTO Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.74. 0x02D8 PG External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x02D8 |            |             | Register Name: PG_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |

|     |     |     |                                                                                                   |
|-----|-----|-----|---------------------------------------------------------------------------------------------------|
| 3:1 | /   | /   | /                                                                                                 |
| 0   | R/W | 0x0 | <b>PIO_INT_CLK_SELECT</b><br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M) |

#### 10.6.5.75. 0x02E0 PH External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x02E0 |            |             | Register Name:PH_EINT_CFG0                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:28          | R/W        | 0x0         | <b>EINT7_CFG</b><br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | <b>EINT6_CFG</b><br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | <b>EINT5_CFG</b><br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | <b>EINT4_CFG</b><br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | <b>EINT3_CFG</b><br>External INT3 Mode                                                                                                                                              |

|      |     |     |                                                                                                                                                                              |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                    |
| 11:8 | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4  | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0  | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 10.6.5.76. 0x02E4 PH External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x02E4 |            |             | Register Name: PH_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT15_CFG<br>External INT15 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT14_CFG                                                                                                                                                                     |

|       |     |     |                                                                                                                                                                                |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | External INT14 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved               |
| 23:20 | R/W | 0x0 | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16 | R/W | 0x0 | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level                                                               |

|     |     |     |                                                                                                                                                                              |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                                     |
| 3:0 | R/W | 0x0 | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

**10.6.5.77. 0x02E8 PH External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)**

| Offset: 0x02E8 |            |             | Register Name: PH_EINT_CFG2                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                              |
| 15:12          | R/W        | 0x0         | EINT19_CFG<br>External INT19 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT18_CFG<br>External INT18 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT17_CFG<br>External INT17 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT16_CFG<br>External INT16 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge                                                                                                  |

|  |  |  |                                                                                               |
|--|--|--|-----------------------------------------------------------------------------------------------|
|  |  |  | 0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
|--|--|--|-----------------------------------------------------------------------------------------------|

#### 10.6.5.78. 0x02F0 PH External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x02F0 |            |             | Register Name: PH_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:20          | /          | /           | /                                                              |
| 19             | R/W        | 0x0         | EINT19_CTL<br>External INT19 Enable<br>0: Disable<br>1: Enable |
| 18             | R/W        | 0x0         | EINT18_CTL<br>External INT18 Enable<br>0: Disable<br>1: Enable |
| 17             | R/W        | 0x0         | EINT17_CTL<br>External INT17 Enable<br>0: Disable<br>1: Enable |
| 16             | R/W        | 0x0         | EINT16_CTL<br>External INT16 Enable<br>0: Disable<br>1: Enable |
| 15             | R/W        | 0x0         | EINT15_CTL<br>External INT15 Enable<br>0: Disable<br>1: Enable |
| 14             | R/W        | 0x0         | EINT14_CTL<br>External INT14 Enable<br>0: Disable<br>1: Enable |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | EINT11_CTL<br>External INT11 Enable                            |

|    |     |     |                                                                |
|----|-----|-----|----------------------------------------------------------------|
|    |     |     | 0: Disable<br>1: Enable                                        |
| 10 | R/W | 0x0 | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9  | R/W | 0x0 | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8  | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7  | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6  | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5  | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4  | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3  | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable   |
| 2  | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable   |
| 1  | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable   |
| 0  | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable<br>0: Disable                |

|  |  |  |           |
|--|--|--|-----------|
|  |  |  | 1: Enable |
|--|--|--|-----------|

**10.6.5.79. 0x02F4 PH External Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x02F4 |            |             | Register Name: PH_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:20          | /          | /           | /                                                                                                        |
| 19             | R/W        | 0x0         | EINT19_STATUS<br>External INT19 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 18             | R/W        | 0x0         | EINT18_STATUS<br>External INT18 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 17             | R/W        | 0x0         | EINT17_STATUS<br>External INT17 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 16             | R/W        | 0x0         | EINT16_STATUS<br>External INT16 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 15             | R/W        | 0x0         | EINT15_STATUS<br>External INT15 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 14             | R/W        | 0x0         | EINT14_STATUS<br>External INT14 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 13             | R/W        | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W        | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit                                                              |

|    |     |     |                                                                                                          |
|----|-----|-----|----------------------------------------------------------------------------------------------------------|
|    |     |     | 0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                                                |
| 11 | R/W | 0x0 | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10 | R/W | 0x0 | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9  | R/W | 0x0 | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8  | R/W | 0x0 | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7  | R/W | 0x0 | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 6  | R/W | 0x0 | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 5  | R/W | 0x0 | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 4  | R/W | 0x0 | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 3  | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit                                                                |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
|   |     |     | 0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                                              |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.5.80. 0x02F8 PH External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x02F8 |            |             | Register Name: PH_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.5.81. 0x0340 PIO Group Withstand Voltage Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: PIO_POW_MOD_SEL                   |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:13          | /          | /           | /                                                |
| 12             | R/W        | 0x0         | VCC_IO POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V |
| 11:10          | /          | /           | /                                                |

|     |     |     |                                                                                                            |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------|
| 9   | R/W | 0x0 | PJ_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PJ_Port Power Source select VCC_IO, this bit is invalid |
| 8   | R/W | 0x0 | PI_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PI_Port Power Source select VCC_IO, this bit is invalid |
| 7   | /   | /   | /                                                                                                          |
| 6   | R/W | 0x0 | PG_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PG_Port Power Source select VCC_IO, this bit is invalid |
| 5   | R/W | 0x0 | PF_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PF_Port Power Source select VCC_IO, this bit is invalid |
| 4   | R/W | 0x0 | PE_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PE_Port Power Source select VCC_IO, this bit is invalid |
| 3   | R/W | 0x0 | PD_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PD_Port Power Source select VCC_IO, this bit is invalid |
| 2   | R/W | 0x0 | PC_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PC_Port Power Source select VCC_IO, this bit is invalid |
| 1:0 | /   | /   | /                                                                                                          |

**NOTE**

When the power domain of GPIO is larger than 1.8 V, the withstand voltage is set to 3.3 V mode, the corresponding value in 0x0340 register is set to 0.

When the power domain of GPIO is 1.8 V, the withstand voltage is set to 1.8 V mode, the corresponding value in 0x0340 register is set to 1.

#### 10.6.5.82. 0x0344 PIO Group Withstand Voltage Mode Select Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: PIO_POW_MS_CTL                |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:13          | /          | /           | /                                            |
| 12             | R/W        | 0x0         | VCC_IO Withstand Voltage Mode Select Control |

|       |     |     |                                                                         |
|-------|-----|-----|-------------------------------------------------------------------------|
|       |     |     | 0: Enable<br>1: Disable                                                 |
| 11:10 | /   | /   | /                                                                       |
| 9     | R/W | 0x0 | VCC_PJ Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 8     | R/W | 0x0 | VCC_PI Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 7     | /   | /   | /                                                                       |
| 6     | R/W | 0x0 | VCC_PG Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 5     | R/W | 0x0 | VCC_PF Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 4     | R/W | 0x0 | VCC_PE Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 3     | R/W | 0x0 | VCC_PD Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 2     | R/W | 0x0 | VCC_PC Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 1:0   | /   | /   | /                                                                       |

**NOTE**

For 1.8 V and 3.3 V power, the withstand function is enabled by default, the corresponding bit in 0x0344 register is set to 0.

For 2.5 V power, the withstand function is disabled, the corresponding bit in 0x0344 register is set to 1, and the withstand mode in 0x0340 register needs be set to 3.3 V.

#### 10.6.5.83. 0x0348 PIO Group Power Value Register(Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: PIO_POW_VAL                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:17          | /          | /           | /                                                                                  |
| 16             | R          | 0x0         | VCC_IO Power Value                                                                 |
| 15:10          | /          | /           | /                                                                                  |
| 9              | R          | 0x0         | PJ_Port Power Value<br>If PJ_Port Power Source selects VCC_IO, this bit is invalid |

|     |   |     |                                                                                    |
|-----|---|-----|------------------------------------------------------------------------------------|
| 8   | R | 0x0 | PI_Port Power Value<br>If PI_Port Power Source selects VCC_IO, this bit is invalid |
| 7   | / | /   | /                                                                                  |
| 6   | R | 0x0 | PG_Port Power Value<br>If PG_Port Power Source selects VCC_IO, this bit is invalid |
| 5   | R | 0x0 | PF_Port Power Value<br>If PF_Port Power Source selects VCC_IO, this bit is invalid |
| 4   | R | 0x0 | PE_Port Power Value<br>If PE_Port Power Source selects VCC_IO, this bit is invalid |
| 3   | R | 0x0 | PD_Port Power Value<br>If PD_Port Power Source selects VCC_IO, this bit is invalid |
| 2   | R | 0x0 | PC_Port Power Value<br>If PC_Port Power Source selects VCC_IO, this bit is invalid |
| 1:0 | / | /   | /                                                                                  |


**NOTE**

When the reading value of the 0x0348 register is 0, it indicates that IO power voltage is greater than 2.5 V.

When the reading value of the 0x0348 register is 1, it indicates that IO power voltage is less than 2.0 V.

#### 10.6.5.84. 0x0350 PIO Group Power Voltage Select Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0350 |            |             | Register Name: PIO_PV_SEL_CTL                             |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:1           | /          | /           | /                                                         |
| 0              | R/W        | 0x1         | VCC-PF Power Voltage Select Control<br>0: 1.8V<br>1: 3.3V |

### 10.6.6. GPIO(PL) Register Description

#### 10.6.6.1. 0x0000 PL Configure Register 0 (Default Value: 0x7777\_7777)

| Offset: 0x0000 |            |             | Register Name: PL_CFG0                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31             | /          | /           | /                                                                                                                                          |
| 30:28          | R/W        | 0x7         | PL7_SELECT<br>000:Input<br>010:S_JTAG_DI<br>100:Reserved<br>110:S_PL_EINT7<br>001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 27             | /          | /           | /                                                                                                                                          |

|       |     |     |                                                                             |                                                              |
|-------|-----|-----|-----------------------------------------------------------------------------|--------------------------------------------------------------|
| 26:24 | R/W | 0x7 | PL6_SELECT<br>000:Input<br>010:S_JTAG_DO<br>100:Reserved<br>110:S_PL_EINT6  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 23    | /   | /   | /                                                                           |                                                              |
| 22:20 | R/W | 0x7 | PL5_SELECT<br>000:Input<br>010:S_JTAG_CK<br>100:Reserved<br>110:S_PL_EINT5  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 19    | /   | /   | /                                                                           |                                                              |
| 18:16 | R/W | 0x7 | PL4_SELECT<br>000:Input<br>010:S_JTAG_MS<br>100:Reserved<br>110:S_PL_EINT4  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 15    | /   | /   | /                                                                           |                                                              |
| 14:12 | R/W | 0x7 | PL3_SELECT<br>000:Input<br>010:S_UART_RX<br>100:Reserved<br>110:S_PL_EINT3  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 11    | /   | /   | /                                                                           |                                                              |
| 10:8  | R/W | 0x7 | PL2_SELECT<br>000:Input<br>010:S_UART_TX<br>100:Reserved<br>110:S_PL_EINT2  | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 7     | /   | /   | /                                                                           |                                                              |
| 6:4   | R/W | 0x7 | PL1_SELECT<br>000:Input<br>010:S_TWI0_SDA<br>100:Reserved<br>110:S_PL_EINT1 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |
| 3     | /   | /   | /                                                                           |                                                              |
| 2:0   | R/W | 0x7 | PLO_SELECT<br>000:Input<br>010:S_TWI0_SCK<br>100:Reserved<br>110:S_PL_EINT0 | 001:Output<br>011:Reserved<br>101:Reserved<br>111:IO Disable |

**10.6.6.2. 0x0004 PL Configure Register 1 (Default Value: 0x0000\_7777)**

| Offset: 0x0004 |            |             | Register Name: PL_CFG1                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:15          | /          | /           | /                                                                                                                                  |
| 14:12          | R/W        | 0x7         | PL11_SELECT<br>000:Input 001:Output<br>010:S_CPU_CUR_W 011:S_CIR_IN<br>100:Reserved 101:Reserved<br>110:S_PL_EINT11 111:IO Disable |
| 11             | /          | /           | /                                                                                                                                  |
| 10:8           | R/W        | 0x7         | PL10_SELECT<br>000:Input 001:Output<br>010:S_PWM 011:Reserved<br>100:Reserved 101:Reserved<br>110:S_PL_EINT10 111:IO Disable       |
| 7              | /          | /           | /                                                                                                                                  |
| 6:4            | R/W        | 0x7         | PL9_SELECT<br>000:Input 001:Output<br>010:S_TWI1_SDA 011:Reserved<br>100:Reserved 101:Reserved<br>110:S_PL_EINT9 111:IO Disable    |
| 3              | /          | /           | /                                                                                                                                  |
| 2:0            | R/W        | 0x7         | PL8_SELECT<br>000:Input 001:Output<br>010:S_TWI1_SCK 011:Reserved<br>100:Reserved 101:Reserved<br>110:S_PL_EINT8 111:IO Disable    |

**10.6.6.3. 0x0010 PL Data Register (Default Value: 0x0000\_0000)**

| Offset: 0x0010 |            |             | Register Name: PL_DAT                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                      |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                |
| 5:0            | R/W        | 0x0         | PL_DAT<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

**10.6.6.4. 0x0014 PL Multi-Driving Register 0 (Default Value: 0x0055\_5555)**

| Offset: 0x0014 |            |             | Register Name: PL_DRV0                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:24          | /          | /           | /                                                                                           |
| 23:22          | R/W        | 0x1         | PL11_DRV<br>PL11 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 21:20          | R/W        | 0x1         | PL10_DRV<br>PL10 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | R/W        | 0x1         | PL9_DRV<br>PL9 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 17:16          | R/W        | 0x1         | PL8_DRV<br>PL8 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 15:14          | R/W        | 0x1         | PL7_DRV<br>PL7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 13:12          | R/W        | 0x1         | PL6_DRV<br>PL6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 11:10          | R/W        | 0x1         | PL5_DRV<br>PL5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 9:8            | R/W        | 0x1         | PL4_DRV<br>PL4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 7:6            | R/W        | 0x1         | PL3_DRV<br>PL3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 5:4            | R/W        | 0x1         | PL2_DRV<br>PL2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |

|     |     |     |                                                                                           |
|-----|-----|-----|-------------------------------------------------------------------------------------------|
| 3:2 | R/W | 0x1 | PL1_DRV<br>PL1 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 1:0 | R/W | 0x1 | PLO_DRV<br>PLO Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 10.6.6.5. 0x001C PL Pull Register 0 (Default Value: 0x0000\_0005)

| Offset: 0x001C |            |             | Register Name: PL_PULL0                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:24          | /          | /           | /                                                                                                           |
| 23:22          | R/W        | 0x0         | PL11_PULL<br>PL11 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 21:20          | R/W        | 0x0         | PL10_PULL<br>PL10 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 19:18          | R/W        | 0x0         | PL9_PULL<br>PL9 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved   |
| 17:16          | R/W        | 0x0         | PL8_PULL<br>PL8 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved   |
| 15:14          | R/W        | 0x0         | PL7_PULL<br>PL7 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved   |
| 13:12          | R/W        | 0x0         | PL6_PULL<br>PL6 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved   |
| 11:10          | R/W        | 0x0         | PL5_PULL<br>PL5 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved   |
| 9:8            | R/W        | 0x0         | PL4_PULL<br>PL4 Pull_up/down Select                                                                         |

|     |     |     |                                                                                                                     |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------|
|     |     |     | 00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved                                        |
| 7:6 | R/W | 0x0 | PL3_PULL<br>PL3 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 5:4 | R/W | 0x0 | PL2_PULL<br>PL2 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 3:2 | R/W | 0x1 | PL1_PULL<br>PL1 Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |
| 1:0 | R/W | 0x1 | PLO_PULL<br>PLO Pull_up/down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down      11: Reserved |

#### 10.6.6.6. 0x0200 PL External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name:PL_EINT_CFG0                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level                                                                               |

|       |     |     |                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved                                                                                                   |
| 19:16 | R/W | 0x0 | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12 | R/W | 0x0 | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8  | R/W | 0x0 | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4   | R/W | 0x0 | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0   | R/W | 0x0 | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

**10.6.6.7. 0x0204 PL External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0204 |            |             | Register Name: PL_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                              |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |

**10.6.6.8. 0x0210 PL External Interrupt Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x0210 |            |             | Register Name: PL_EINT_CTL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:12          | /          | /           | /                          |
| 11             | R/W        | 0x0         | EINT11_CTL                 |

|    |     |     |                                                                |
|----|-----|-----|----------------------------------------------------------------|
|    |     |     | External INT11 Enable<br>0: Disable<br>1: Enable               |
| 10 | R/W | 0x0 | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9  | R/W | 0x0 | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8  | R/W | 0x0 | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7  | R/W | 0x0 | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6  | R/W | 0x0 | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5  | R/W | 0x0 | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4  | R/W | 0x0 | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3  | R/W | 0x0 | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable   |
| 2  | R/W | 0x0 | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable   |
| 1  | R/W | 0x0 | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable   |
| 0  | R/W | 0x0 | EINT0_CTL<br>External INT0 Enable                              |

|  |  |  |                         |
|--|--|--|-------------------------|
|  |  |  | 0: Disable<br>1: Enable |
|--|--|--|-------------------------|

**10.6.6.9. 0x0214 PL External Interrupt Status Register(Default Value: 0x0000\_0000)**

| Offset: 0x214 |            |             | Register Name: PL_EINT_STATUS                                                                            |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                              |
| 31:12         | /          | /           | /                                                                                                        |
| 11            | R/W        | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10            | R/W        | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9             | R/W        | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8             | R/W        | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7             | R/W        | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 6             | R/W        | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 5             | R/W        | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 4             | R/W        | 0x0         | EINT4_STATUS                                                                                             |

|   |     |     |                                                                                                        |
|---|-----|-----|--------------------------------------------------------------------------------------------------------|
|   |     |     | External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                 |
| 3 | R/W | 0x0 | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2 | R/W | 0x0 | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1 | R/W | 0x0 | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0 | R/W | 0x0 | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 10.6.6.10. 0x0218 PL External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0218 |            |             | Register Name: PL_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz(OSC24M)           |

#### 10.6.6.11. 0x0340 PIO Group Withstand Voltage Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0340 | Register Name: PIO_POW_MOD_SEL |
|----------------|--------------------------------|
|----------------|--------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                  |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| 31:13 | /          | /           | /                                                                                                            |
| 12    | R/W        | 0x0         | VCC_IO POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V                                                             |
| 11:1  | /          | /           | /                                                                                                            |
| 0     | R/W        | 0x0         | PL_POWER MODE Select<br>0: 1.8 V<br>1: 3.3 V<br>If PL_Port Power Source selects VCC_IO, this bit is invalid. |

**NOTE**

When the power domain of GPIO is larger than 1.8 V, the withstand voltage is set to 3.3 V mode, the corresponding value in 0x0340 register is set to 0.

When the power domain of GPIO is 1.8 V, the withstand voltage is set to 1.8 V mode, the corresponding value in 0x0340 register is set to 1.

#### 10.6.6.12. 0x0344 PIO Group Withstand Voltage Mode Select Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: PIO_POW_MS_CTL                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:1           | /          | /           | /                                                                       |
| 0              | R/W        | 0x0         | VCC_PL Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |

**NOTE**

For 1.8 V and 3.3 V power, the withstand function is enabled by default, the corresponding bit in 0x0344 register is set to 0.

For 2.5 V power, the withstand function is disabled, the corresponding bit in 0x0344 register is set to 1, and the withstand mode in 0x0340 register needs be set to 3.3 V.

#### 10.6.6.13. 0x0348 PIO Group Power Value Register (Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: PIO_POW_VAL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:17          | /          | /           | /                          |
| 16             | R          | 0x0         | VCC_IO Power Value         |
| 15:1           | /          | /           | /                          |
| 0              | R          | 0x0         | PL_Port Power Value        |

|  |  |  |                                                           |
|--|--|--|-----------------------------------------------------------|
|  |  |  | If PL_Port Power Source select VCC_IO,this bit is invalid |
|--|--|--|-----------------------------------------------------------|

**NOTE**

When the reading value of the 0x0348 register is 0, it indicates that IO power voltage is greater than 2.5 V.

When the reading value of the 0x0348 register is 1, it indicates that IO power voltage is less than 2.0 V.

## 10.7. GPADC

### 10.7.1. Overview

The General Purpose ADC(GPADC) is one analog to digital converter with 12-bit sampling resolution. This ADC is a type of successive approximation register (SAR) converter.

The GPADC has the following features:

- 12-bit resolution
- 8-bit effective SAR type A/D converter
- 64 FIFO depth of data register
- Power reference voltage: 1.8 V, analog input voltage range: 0 to 1.8 V
- Maximum sampling frequency: 1 MHz
- Supports data compare and interrupt
- Supports DMA transport
- Supports three operation modes
  - Single conversion mode
  - Continuous conversion mode
  - Burst conversion mode

### 10.7.2. Block Diagram

Figure 10-36 shows the block diagram of the GPADC.



Figure 10- 36. GPADC Block Diagram

### 10.7.3. Operations and Functional Descriptions

#### 10.7.3.1. External Signals

Table 10-25 describes the external signals of GPADC.

**Table 10- 25. GPADC External Signals**

| Signal | Description       | Type |
|--------|-------------------|------|
| GPADC1 | ADC Input Channel | AI   |

#### 10.7.3.2. Clock Sources

GPADC has one clock source. Table 10-26 describes the clock source for GPADC. Users can see **Clock Controller Unit(CCU)** for clock setting, configuration and gating information.

**Table 10- 26. GPADC Clock Sources**

| Clock Sources | Description |
|---------------|-------------|
| OSC24M        | 24MHz       |

#### 10.7.3.3. GPADC Work Mode

##### (1).Single conversion mode

GPADC completes one conversion in specified channel, the converted data is updated at the data register of corresponding channel.

##### (2).Continuous conversion mode

GPADC has continuous conversion in specified channel until the software stops, the converted data is updated at the data register of corresponding channel.

##### (3).Burst conversion mode

GPADC samples and converts in the specified channel, and sequentially stores the results in FIFO.

#### 10.7.3.4. Clock and Timing Requirements

CLK\_IN = 24 MHz

CONV\_TIME(Conversion Time) = 1/(24 MHz/14 Cycles) =0.583 (us)

TACQ> 10RC (R is output impedance of ADC sample circuit, C= 6.4 pF)

ADC Sample Frequency > TACQ+CONV\_TIME



Figure 10- 37. GPADC Clock and Timing Requirement

#### 10.7.3.5. GPADC Calculate Formula

GPADC calculate formula:  $GPADC\_DATA = Vin/V_{REF} * 4096$

Where:

$V_{REF}=1.8\text{ V}$

#### 10.7.4. Programming Guidelines

The GPADC initial process is as follows.



Figure 10- 38. GPADC Initial Process

#### 10.7.5. Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|       |            |
|-------|------------|
| GPADC | 0x05070000 |
|-------|------------|

| Register Name   | Offset | Description                                  |
|-----------------|--------|----------------------------------------------|
| GP_SR_CON       | 0x0000 | GPADC Sample Rate Configure Register         |
| GP_CTRL         | 0x0004 | GPADC Control Register                       |
| GP_CS_EN        | 0x0008 | GPADC Compare and Select Enable Register     |
| GP_FIFO_INTC    | 0x000C | GPADC FIFO Interrupt Control Register        |
| GP_FIFO_INTS    | 0x0010 | GPADC FIFO Interrupt Status Register         |
| GP_FIFO_DATA    | 0x0014 | GPADC FIFO Data Register                     |
| GP_CDATA        | 0x0018 | GPADC Calibration Data Register              |
| GP_DATAL_INTC   | 0x0020 | GPADC Data Low Interrupt Configure Register  |
| GP_DATAH_INTC   | 0x0024 | GPADC Data High Interrupt Configure Register |
| GP_DATA_L_INTC  | 0x0028 | GPADC Data Low Interrupt Configure Register  |
| GP_DATAL_INTS   | 0x0030 | GPADC Data Low Interrupt Status Register     |
| GP_DATAH_INTS   | 0x0034 | GPADC Data High Interrupt Status Register    |
| GP_DATA_INTS    | 0x0038 | GPADC Data Interrupt Status Register         |
| GP_CH1_CMP_DATA | 0x0044 | GPADC CH1 Compare Data Register              |
| GP_CH1_DATA     | 0x0084 | GPADC CH1 Data Register                      |

### 10.7.6. Register Description

#### 10.7.6.1. 0x0000 GPADC Sample Rate Configure Register (Default Value: 0x01DF\_002F)

| Offset: 0x0000 |            |             | Register Name: GP_SR_CON                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:16          | R/W        | 0x1DF       | FS_DIV<br>ADC sample frequency divider<br>CLK_IN/(n+1)<br>Default value: 50K |
| 15:0           | R/W        | 0x2F        | TACQ<br>ADC acquire time<br>CLK_IN/(N+1)<br>Default value: 2us               |

#### 10.7.6.2. 0x0004 GPADC Control Register (Default Value: 0x0080\_0000)

| Offset: 0x0004 |            |             | Register Name: GP_CTRL                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:24          | R/ W       | 0x0         | ADC_FIRST_DLY<br>ADC First Convert Delay Setting<br>ADC conversion of each channel is delayed by N samples. |
| 23             | R/ W       | 0x1         | ADC_AUTOCALI_EN                                                                                             |

|       |     |     |                                                                                                                                                                                                                                                                                              |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | ADC Auto Calibration                                                                                                                                                                                                                                                                         |
| 22    | /   | /   | /                                                                                                                                                                                                                                                                                            |
| 21:20 | R/W | 0x0 | ADC_OP_BIAS<br>ADC OP Bias<br>Adjust the bandwidth of the ADC amplifier                                                                                                                                                                                                                      |
| 19:18 | R/W | 0x0 | GPADC Work Mode<br>00: Single conversion mode<br>01: Reserved<br>10: Continuous conversion mode<br>11: Burst conversion mode                                                                                                                                                                 |
| 17    | R/W | 0x0 | ADC_CALI_EN<br>ADC Calibration<br>1: Start Calibration, it is cleared to 0 after calibration                                                                                                                                                                                                 |
| 16    | R/W | 0x0 | ADC_EN<br>ADC Function Enable<br>Before the bit is enabled, configure ADC parameters including the work mode and channel number,etc.<br>0: Disable<br>1: Enable<br><b>Note: If selecting single conversion mode, when the conversion is completed, the bit can clear to 0 automatically.</b> |
| 15:0  | /   | /   | /                                                                                                                                                                                                                                                                                            |

#### 10.7.6.3. 0x0008 GPADC Compare and Select Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: GP_CS_EN                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:18          | /          | /           | /                                                                          |
| 17             | R/W        | 0x0         | ADC_CH1_CMP_EN<br>Channel 1 Compare Enable<br>0: Disable<br>1: Enable      |
| 16:2           | /          | /           | /                                                                          |
| 1              | R/W        | 0x0         | ADC_CH1_SELECT<br>Analog Input Channel 1 Select<br>0: Disable<br>1: Enable |
| 0              | /          | /           | /                                                                          |

#### 10.7.6.4. 0x000C GPADC FIFO Interrupt Control Register (Default Value: 0x0000\_1F00)

| Offset: 0x000C | Register Name: GP_FIFO_INTC |
|----------------|-----------------------------|
|----------------|-----------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                             |
|-------|------------|-------------|-----------------------------------------------------------------------------------------|
| 31:19 | /          | /           | /                                                                                       |
| 18    | R/W        | 0x0         | FIFO_DATA_DRQ_EN<br>ADC FIFO Date DRQ Enable<br>0: Disable<br>1: Enable                 |
| 17    | R/W        | 0x0         | FIFO_OVERRUN_IRQ_EN<br>ADC FIFO Overrun IRQ Enable<br>0: Disable<br>1: Enable           |
| 16    | R/W        | 0x0         | FIFO_DATA_IRQ_EN<br>ADC FIFO Data Available IRQ Enable<br>0: Disable<br>1: Enable       |
| 15:14 | /          | /           | /                                                                                       |
| 13:8  | R/W        | 0x1F        | FIFO_TRIG_LEVEL<br>Interrupt trigger level for ADC<br>Trigger Level = TXTL + 1          |
| 7:5   | /          | /           | /                                                                                       |
| 4     | R/WAC      | 0x0         | FIFO_FLUSH<br>ADC FIFO Flush<br>Write '1' to flush TX FIFO, clear automatically to '0'. |
| 3:0   | /          | /           | /                                                                                       |

#### 10.7.6.5. 0x0010 GPADC FIFO Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: GP_FIFO_INTS                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:18          | /          | /           | /                                                                                                                                                    |
| 17             | R/W1C      | 0x0         | FIFO_OVERRUN_PENDING<br>ADC FIFO Overrun IRQ Pending<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt.       |
| 16             | R/W1C      | 0x0         | FIFO_DATA_PENDING<br>ADC FIFO Data Available Pending Bit<br>0: NO Pending IRQ<br>1: FIFO Available Pending IRQ<br>Write '1' to clear this interrupt. |
| 15:14          | /          | /           | /                                                                                                                                                    |
| 13:8           | R          | 0x0         | RXA_CNT<br>ADC FIFO Available Sample Word Counter                                                                                                    |
| 7:0            | /          | /           | /                                                                                                                                                    |

#### 10.7.6.6. 0x0014 GPADC FIFO Data Register

| Offset: 0x0014 |            |             | Register Name: GP_FIFO_DATA        |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:12          | /          | /           | /                                  |
| 11:0           | R          | UDF         | GP_FIFO_DATA<br>GPADC Data in FIFO |

#### 10.7.6.7. 0x0018 GPADC Calibration Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: GP_CDATA            |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:12          | /          | /           | /                                  |
| 11:0           | R/W        | 0x0         | GP_CDATA<br>GPADC Calibration Data |

#### 10.7.6.8. 0x0020 GPADC Low Interrupt Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: GP_DATA1_INTC              |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:2           | /          | /           | /                                         |
| 1              | R/W        | 0x0         | CH1_LOW_IRQ_EN<br>0: Disable<br>1: Enable |
| 0              | /          | /           | /                                         |

#### 10.7.6.9. 0x0024 GPADC High Interrupt Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: GP_DATAH_INTC              |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:2           | /          | /           | /                                         |
| 1              | R/W        | 0x0         | CH1_HIG_IRQ_EN<br>0: Disable<br>1: Enable |
| 0              | /          | /           | /                                         |

**10.7.6.10. 0x0028 GPADC DATA Interrupt Configure Register (Default Value: 0x0000\_0000)**

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

**10.7.6.11. 0x0030 GPADC Low Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0030 |            |             | Register Name: GP_DATAL_INTS                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31:2           | /          | /           | /                                                                                                                                                            |
| 1              | R/W1C      | 0x0         | CH1_LOW_PENGDING<br>1: Channel 1 Voltage Low Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if interrupt condition fails. |
| 0              | /          | /           | /                                                                                                                                                            |

**10.7.6.12. 0x0034 GPADC High Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0034 |            |             | Register Name: GP_DATAH_INTS                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:2           | /          | /           | /                                                                                                                                                                                  |
| 1              | R/W1C      | 0x0         | CH1_HIG_PENGDING<br>0: No Pending IRQ<br>1: Channel 1 Voltage High Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if interrupt condition fails. |
| 0              | /          | /           | /                                                                                                                                                                                  |

**10.7.6.13. 0x0038 GPADC Data Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0038 |            |             | Register Name: GP_DATA_INTS                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:2           | /          | /           | /                                                                                 |
| 1              | R/W1C      | 0x0         | CH1_DATA_PENGDING<br>0: No Pending IRQ<br>1: Channel 1 Data Available Pending IRQ |

|   |   |   |                                                                                        |
|---|---|---|----------------------------------------------------------------------------------------|
|   |   |   | Write '1' to clear this interrupt or automatically clear if interrupt condition fails. |
| 0 | / | / | /                                                                                      |

#### 10.7.6.14. 0x0044 GPADC CH1 Compare Data Register (Default Value: 0x0BFF\_0400)

| Offset: 0x0044 |            |             | Register Name: GP_CH1_CMP_DATA                   |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:28          | /          | /           | /                                                |
| 27:16          | R/W        | 0xBFF       | CH1_CMP_HIG_DATA<br>Channel 1 Voltage High Value |
| 15:12          | /          | /           | /                                                |
| 11:0           | R/W        | 0x400       | CH1_CMP_LOW_DATA<br>Channel 1 Voltage Low Value  |

#### 10.7.6.15. 0x0084 GPADC CH1 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: GP_CH1_DATA    |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:12          | /          | /           | /                             |
| 11:0           | R          | 0x000       | GP_CH1_DATA<br>Channel 1 Data |

## 10.8. LRADC

### 10.8.1. Overview

The Low Rate ADC(LRADC) is 6-bit resolution for Key application. The LRADC can work up to maximum conversion rate of 2 kHz.

- Power supply voltage:1.8 V; reference voltage:1.35 V
- Interrupt support
- Support Hold Key and General Key
- Support normal, continue and single work mode
- 6-bits resolution, sample rate up to 2 kHz
- Voltage input range between 0 to 1.35 V

### 10.8.2. Block Diagram

Figure 10-39 shows a block diagram of the LRADC.



Figure 10- 39. LRADC Block Diagram

### 10.8.3. Operations and Functional Descriptions

#### 10.8.3.1. External Signals

Table 10-27 describes the external signal of LRADC.

**Table 10- 27. LRADC External Signals**

| Signal | Description | Type |
|--------|-------------|------|
| LRADC  | ADC Input   | AI   |

### 10.8.3.2. Clock Sources

Table 10-28 describes the clock source for LRADC.

**Table 10- 28. LRADC Clock Sources**

| Clock Sources | Description     |
|---------------|-----------------|
| LOSC          | 32.768 kHz LOSC |

### 10.8.3.3. LRADC Work Mode

#### (1). Normal Mode

ADC gathers 8 samples, the average of the 8 samples is updated in data register, and the data interrupt sign is enabled. It is sampled repeatedly according to this mode until ADC stop.

#### (2). Continue Mode

ADC gathers 8 samples every other  $8*(N+1)$  sample cycle. The average of every 8 samples is updated in the data register, and the data interrupt sign is enabled. (N is defined in the bit[19:16] of **LRADC\_CTRL\_REG**).

#### (3).Single Mode

ADC gathers 8 samples, the average of the 8 samples is updated in data register, and the data interrupt sign is enabled, since then ADC stops sample.

### 10.8.3.4. Interrupt

Each LRADC channel has five interrupt sources and five interrupt enable controls.

**Figure 10- 40. LRADC Interrupt**

When input voltage is between LEVELA(1.35V) and LEVELB(control by the bit[5:4] of LRADC\_CTRL), IRQ1 can be generated. When input voltage is lower than LEVELB, IRQ2 can be generated.

If the controller receives IRQ1, and does not receive IRQ2 at some time, then the controller will generate Hold KEY Interrupt, otherwise DATA\_IRQ Interrupt.

Hold KEY usually is used for self-locking key. When self-locking key holds locking status, the controller receives IRQ2, then the controller will generate Already Hold Key Interrupt.

#### 10.8.4. Programming Guidelines



Figure 10- 41. LRADC Initial Process

- (1) Set CONTINUE\_TIME\_SELECT(the bit[11:8] of LRADC\_CTRL) when LRADC works in continue mode.
- (2) The range of input voltage is from 0 to LEVELB(the bit[5:4] of LRADC\_CTRL).
- (3) Calculation formula: LRADC\_DATA = Vin/V<sub>REF</sub>\*64, V<sub>REF</sub>=1.35 V
- (4) LRADC has 6-bit resolution, 1-bit offset error, 1-bit quantizing error. After LRADC calibrates 1-bit offset error, LRADC has 5-bit resolution.

#### 10.8.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| LRADC       | 0x05070800   |

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| LRADC_CTRL    | 0x0000 | LRADC Control Register           |
| LRADC_INTC    | 0x0004 | LRADC Interrupt Control Register |
| LRADC_INTS    | 0x0008 | LRADC Interrupt Status Register  |
| LRADC_DATA0   | 0x000C | LRADC Data Register0             |

## 10.8.6. Register Description

### 10.8.6.1. 0x0000 LRADC Control Register (Default Value: 0x0100\_0168)

| Offset: 0x0000 |            |             | Register Name: LRADC_CTRL                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                              |
| 31: 24         | R/W        | 0x1         | FIRST_CONVERT_DLY<br>ADC First Convert Delay Setting<br>ADC conversion is delayed by n samples.                                                                          |
| 23:20          | /          | /           | /                                                                                                                                                                        |
| 19:16          | R/W        | 0x0         | CONTINUE_TIME_SELECT<br>Continue Mode Time Select<br>One of 8*(N+1) sample as a valuable sample data.                                                                    |
| 15:14          | /          | /           | /                                                                                                                                                                        |
| 13:12          | R/W        | 0x0         | KEY_MODE_SELECT<br>Key Mode Select<br>00: Normal Mode<br>01: Single Mode<br>10: Continue Mode                                                                            |
| 11:8           | R/W        | 0x1         | LEVELA_B_CNT<br>Level A to Level B time threshold select, judge ADC convert value in level A to level B in n+1 samples.                                                  |
| 7              | R/W        | 0x0         | LRADC_HOLD_KEY_EN<br>LRADC Hold KEY Enable<br>0: Disable<br>1: Enable                                                                                                    |
| 6              | R/W        | 0x1         | LRADC_CHANNEL_EN<br>LRADC Channel Enable<br>0: Disable<br>1: Enable                                                                                                      |
| 5: 4           | R/W        | 0x2         | LEVELB_VOL.<br>Level B Corresponding Data Value Setting (the real voltage value)<br>00: 0x3C (1.266 V)<br>01: 0x39 (1.202 V)<br>10: 0x36 (1.139 V)<br>11: 0x33 (1.076 V) |
| 3: 2           | R/W        | 0x2         | LRADC_SAMPLE_RATE<br>LRADC Sample Rate<br>00: 2 kHz<br>01: 1 kHz<br>10: 500 Hz<br>11: 250 Hz                                                                             |
| 1              | /          | /           | /                                                                                                                                                                        |
| 0              | R/W        | 0x0         | LRADC_EN<br>LRADC Enable                                                                                                                                                 |

|  |  |  |                         |
|--|--|--|-------------------------|
|  |  |  | 0: Disable<br>1: Enable |
|--|--|--|-------------------------|

#### 10.8.6.2. 0x0004 LRADC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: LRADC_INTC                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:5           | /          | /           | /                                                                                     |
| 4              | R/W        | 0x0         | ADCO_KEYUP_IRQ_EN<br>ADCO Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 3              | R/W        | 0x0         | ADCO_ALRDY_HOLD_IRQ_EN<br>ADCO Already Hold Key IRQ Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | ADCO_HOLD_IRQ_EN<br>ADCO Hold Key IRQ Enable<br>0: Disable<br>1: Enable               |
| 1              | R/W        | 0x0         | ADCO_KEYDOWN_EN<br>ADCO Key Down Enable<br>0: Disable<br>1: Enable                    |
| 0              | R/W        | 0x0         | ADCO_DATA_IRQ_EN<br>ADCO Data IRQ Enable<br>0: Disable<br>1: Enable                   |

#### 10.8.6.3. 0x0008 LRADC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: LRADC_INTS                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                          |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                    |
| 4              | R/W1C      | 0x0         | ADCO_KEYUP_PENDING<br>ADCO Key up Pending Bit<br>When general key is pulled up, and the corresponding interrupt is enabled, the status bit is set.<br>0: No IRQ<br>1: IRQ Pending<br>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled. |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                 |
|---|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | R/W1C | 0x0 | <p><b>ADC0_ALRDY_HOLD_PENDING</b><br/>ADC0 Already Hold Pending Bit<br/>When hold key is pulled down and the general key is pulled down, and the corresponding interrupt is enabled.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                   |
| 2 | R/W1C | 0x0 | <p><b>ADC0_HOLDKEY_PENDING</b><br/>ADC0 Hold Key Pending Bit<br/>When hold key is pulled down, and the corresponding interrupt is enabled, the status bit is set and the interrupt line is set.<br/>0: NO IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>        |
| 1 | R/W1C | 0x0 | <p><b>ADC0_KEYDOWN_PENDING</b><br/>ADC0 Key Down IRQ Pending Bit<br/>When general key is pulled down, and the corresponding interrupt is enabled, the status bit is set and the interrupt line is set.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p> |
| 0 | R/W1C | 0x0 | <p><b>ADC0_DATA_PENDING</b><br/>ADC0 Data IRQ Pending Bit<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                                                                                                                                              |

#### 10.8.6.4. 0x000C LRADC Data Register0 (Default Value: 0x0000\_003F)

| <b>Offset: 0x000C</b> |                   | <b>Register Name: LRADC_DATA0</b> |                            |
|-----------------------|-------------------|-----------------------------------|----------------------------|
| <b>Bit</b>            | <b>Read/Write</b> | <b>Default/Hex</b>                | <b>Description</b>         |
| 31:6                  | /                 | /                                 | /                          |
| 5:0                   | R                 | 0x3F                              | LRADCO_DATA<br>LRADCO Data |

## 10.9. CIR Receiver

### 10.9.1. Overview

The Consumer Infrared(CIR) receiver is a capturer of the pulse from IR Receiver module and uses Run-Length Code (RLC) to encode the pulse. The CIR receiver samples the input signal on the programmable frequency and records these samples into RX FIFO when one CIR signal is found on the air. The CIR receiver uses Run-Length Code (RLC) to encode pulse width. The encoded data is buffered in a 64 levels and 8-bit width RX FIFO; the MSB bit is used to record the polarity of the receiving CIR signal. The high level is represented as '1' and the low level is represented as '0'. The rest 7 bits are used for the length of RLC. The maximum length is 128. If the duration of one level (high or low level) is more than 128, another byte is used.

In the air, there is always some noise. One threshold can be set to filter the noise to reduce system loading and improve the system stability.

The CIR receiver has the following features:

- Full physical layer implementation
- Supports CIR for remote control or wireless keyboard
- 64x8 bits FIFO for data buffer
- Programmable FIFO thresholds
- Interrupt support
- Sample clock up to 1 MHz

### 10.9.2. Block Diagram

Figure 10-42 shows a block diagram of the CIR receiver.



Figure 10- 42. CIR Receiver Block Diagram

### 10.9.3. Operations and Functional Descriptions

#### 10.9.3.1. External Signals

Table 10-29 describes the external signals of CIR Receiver.

**Table 10- 29. CIR Receiver External Signals**

| Signal   | Description                        | Type |
|----------|------------------------------------|------|
| CIR_IN   | Consumer infrared receiver in CPUX | I    |
| S_CIR_IN | Consumer infrared receiver in CPUS | I    |

#### 10.9.3.2. Clock Sources



**Figure 10- 43. CIR Receiver Clock**

#### 10.9.3.3. Typical Application



**Figure 10- 44. CIR Receiver Application Diagram**

#### 10.9.3.4. Function Implementation



**Figure 10- 45. NEC Protocol**

In fact, CIR receiver module is a timer with capture function.

When CIR\_RX signals satisfy ATHR (Active Threshold), CIR receiver can start to capture. In the process, the signal is ignored if the pulse width of the signal is less than NTHR. When CIR\_RX signals satisfy ITHR (Idle Threshold), the capture process is stopped and the Receiver Packet End interrupt is generated, then Receiver Packet End Flag is asserted.

In a capture process, every effective pulse is buffered to FIFO in bytes according to the form of Run-Length Code. The MSB bit of a byte is polarity of pulse, and the rest 7 bits is pulse width by taking Sample Clock as basic unit. This is the code form of RLC-Byte. When the level changes or the pulse width counting overflows, RLC-Byte is buffered to FIFO. The CIR\_RX module receives infrared signals transmitted by the infrared remote control, the software decodes the signals.

#### 10.9.3.5. Operating Mode

- **Sample Clock**



**Figure 10- 46. Logical '0' and Logical '1' of NEC Protocol**

For NEC protocol, a logical "1" takes 2.25ms(560us+1680us) to transmit, while a logical "0" is only half of that, being 1.12ms(560us+560us). For example, if sample clock is 31.25 kHz, a sample cycle is 32us, then 18 sample cycles are 560us. So the RLC of 560us low level is 0x12(b'00010010), the RLC of 560us high level is 0x92(b' 10010010). Then a logical "1" takes code 0x12(b'00010010) and code 0xb5(b' 10110101) to transmit, a logical "0" takes code 0x12 and code 0x92 to transmit.

- **ATHR(Active Threshold)**

When CIR receiver is in Idle state, if electrical level of CIR\_RX signal changes (positive jump or negative jump), and the duration reaches this threshold, then CIR takes the starting of the signal as a lead code, turns into active state and starts to capture CIR\_RX signals.



Figure 10- 47. ATHR Definition

- **ITHR(Idle Threshold)**

If electrical level of CIR\_RX signals has no change, and the duration reaches this threshold, then CIR receiver enters into Idle state and ends this capture.



Figure 10- 48. ITHR Definition

- **NTHR(Noise Threshold)**

In capture process, the pulse is ignored if the pulse width is less than Noise Threshold.



Figure 10- 49. NTHR Definition

- **APAM(Active Pulse Accept Mode)**

APAM is used to fit the type of lead code. If a pulse does not fit the type of lead code, it is not regarded as a lead code even if the pulse width reaches ATHR.



Figure 10- 50. APAM Definition

#### 10.9.4. Programming Guidelines



Figure 10- 51. CIR Receiver Process

### 10.9.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| CIR_RX      | 0x05071800   |
| R_CIR_RX    | 0x07040000   |

| Register Name | Offset | Description                             |
|---------------|--------|-----------------------------------------|
| CIR_CTL       | 0x0000 | CIR Control Register                    |
| CIR_RXPCFG    | 0x0010 | CIR Receiver Pulse Configure Register   |
| CIR_RXFIFO    | 0x0020 | CIR Receiver FIFO Register              |
| CIR_RXINT     | 0x002C | CIR Receiver Interrupt Control Register |
| CIR_RXSTA     | 0x0030 | CIR Receiver Status Register            |
| CIR_RXCFG     | 0x0034 | CIR Receiver Configure Register         |

### 10.9.6. Register Description

#### 10.9.6.1. 0x0000 CIR Receiver Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CIR_CTL                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                             |
| 7:6            | R/W        | 0x0         | Active Pulse Accept Mode<br>00, 01: Both positive and negative pulses are valid as a leading code<br>10: Only negative pulse is valid as a leading code<br>11: Only positive pulse is valid as a leading code |
| 5:4            | R/W        | 0x0         | CIR ENABLE<br>00~10: Reserved<br>11: CIR mode enable                                                                                                                                                          |
| 3:2            | /          | /           | /                                                                                                                                                                                                             |
| 1              | R/W        | 0x0         | RXEN<br>Receiver Block Enable<br>0: Disable<br>1: Enable                                                                                                                                                      |
| 0              | R/W        | 0x0         | GEN<br>Global Enable<br>A disable on this bit overrides any other block or channel enables and flushes all FIFOs.<br>0: Disable<br>1: Enable                                                                  |

**10.9.6.2. 0x0010 CIR Receiver Pulse Configure Register(Default Value: 0x0000\_0004)**

| Offset: 0x0010 |            |             | Register Name: CIR_RXPCFG                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:3           | /          | /           | /                                                                                                       |
| 2              | R/W        | 0x1         | RPPI<br>Receiver Pulse Polarity Invert<br>0: Do not invert receiver signal<br>1: Invert receiver signal |
| 1:0            | /          | /           | /                                                                                                       |

**10.9.6.3. 0x0020 CIR Receiver FIFO Register(Default Value: 0x0000\_0000)**

| Offset: 0x0020 |            |             | Register Name: CIR_RXFIFO |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:8           | /          | /           | /                         |
| 7:0            | R          | 0x0         | Receiver Byte FIFO        |

**10.9.6.4. 0x002C CIR Receiver Interrupt Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x002C |            |             | Register Name: CIR_RXINT                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:14          | /          | /           | /                                                                                                                                                                                           |
| 13:8           | R/W        | 0x0         | RAL<br>RX FIFO available received byte level for interrupt and DMA request<br>TRIGGER_LEVEL = RAL + 1                                                                                       |
| 5              | R/W        | 0x0         | DRQ_EN<br>RX FIFO DMA Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Receiver FIFO DRQ is asserted if reaching RAL. The DRQ is de-asserted when condition fails.                 |
| 4              | R/W        | 0x0         | RAI_EN<br>RX FIFO Available Interrupt Enable<br>0: Disable<br>1: Enable<br>When set to '1', the Receiver FIFO IRQ is asserted if reaching RAL. The IRQ is de-asserted when condition fails. |
| 3:2            | /          | /           | /                                                                                                                                                                                           |
| 1              | R/W        | 0x0         | RPEI_EN<br>Receiver Packet End Interrupt Enable<br>0: Disable                                                                                                                               |

|   |     |     |                                                                             |
|---|-----|-----|-----------------------------------------------------------------------------|
|   |     |     | 1: Enable                                                                   |
| 0 | R/W | 0x0 | ROI_EN<br>Receiver FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable |

#### 10.9.6.5. 0x0030 CIR Receiver Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CIR_RXSTA                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                       |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                 |
| 13:8           | R          | 0x0         | <b>RAC</b><br>RX FIFO Available Counter<br>0: No available data in RX FIFO<br>1: 1 byte available data in RX FIFO<br>2: 2 byte available data in RX FIFO<br>...<br>64: 64 byte available data in RX FIFO                                                                                                          |
| 7              | R          | 0x0         | <b>STAT</b><br>Status of CIR<br>0: Idle<br>1: Busy                                                                                                                                                                                                                                                                |
| 6:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                 |
| 4              | R/W1C      | 0x0         | <b>RA</b><br>RX FIFO Available<br>0: RX FIFO not available according its level<br>1: RX FIFO available according its level<br>This bit is cleared by writing a '1'.                                                                                                                                               |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                 |
| 1              | R/W1C      | 0x0         | <b>RPE</b><br>Receiver Packet End Flag<br>0: STO was not detected. In CIR mode, one CIR symbol is receiving or not detected.<br>1: STO field or packet abort symbol (7'b0000,000 and 8'b0000,0000 for MIR and FIR) is detected. In CIR mode, one CIR symbol is received.<br>This bit is cleared by writing a '1'. |
| 0              | R/W1C      | 0x0         | <b>ROI</b><br>Receiver FIFO Overrun<br>0: Receiver FIFO not overrun<br>1: Receiver FIFO overrun<br>This bit is cleared by writing a '1'.                                                                                                                                                                          |

**10.9.6.6. 0x0034 CIR Receiver Configure Register(Default Value: 0x0000\_1828)**

| Offset: 0x0034 |            |             | Register Name: CIR_RXCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |        |        |              |   |   |   |            |   |   |   |              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|--------|--------------|---|---|---|------------|---|---|---|--------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |        |        |              |   |   |   |            |   |   |   |              |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |        |        |              |   |   |   |            |   |   |   |              |
| 24             | R/W        | 0x0         | SCS2<br>Bit 2 of Sample Clock Select for CIR<br>This bit is defined by SCS bits below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |        |        |              |   |   |   |            |   |   |   |              |
| 23             | R/W        | 0x0         | ATHC<br>Active Threshold Control for CIR<br>0: ATHR in unit of (Sample Clock)<br>1: ATHR in unit of (128*Sample Clocks)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |        |        |              |   |   |   |            |   |   |   |              |
| 22:16          | R/W        | 0x0         | ATHR<br>Active Threshold for CIR<br>These bits control the duration of CIR from idle to active state. The duration can be calculated by ((ATHR + 1)*(ATHC? Sample Clock: 128*Sample Clock)).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |        |        |              |   |   |   |            |   |   |   |              |
| 15:8           | R/W        | 0x18        | ITHR<br>Idle Threshold for CIR<br>The Receiver uses it to decide whether the CIR command has been received. If there is no CIR signal on the air, the receiver is staying in IDLE status. One active pulse will bring the receiver from IDLE status to Receiving status. After the CIR is end, the inputting signal will keep the specified level (high or low level) for a long time. The receiver can use this idle signal duration to decide that it has received the CIR command. The corresponding flag is asserted. If the corresponding interrupt is enabled, the interrupt line is asserted to CPU. When the duration of signal keeps one status (high or low level) for the specified duration ( (ITHR + 1)*128 sample_clk ), this means that the previous CIR command has been finished. |      |        |        |              |   |   |   |            |   |   |   |              |
| 7:2            | R/W        | 0xA         | NTHR<br>Noise Threshold for CIR<br>When the duration of signal pulse (high or low level) is less than NTHR, the pulse is taken as noise and should be discarded by hardware.<br>0: All samples are recorded into RX FIFO<br>1: If the signal is only one sample duration, it is taken as noise and discarded.<br>2: If the signal is less than (<=) two sample duration, it is taken as noise and discarded.<br>...<br>61: If the signal is less than (<=) sixty-one sample duration, it is taken as noise and discarded.                                                                                                                                                                                                                                                                          |      |        |        |              |   |   |   |            |   |   |   |              |
| 1:0            | R/W        | 0x0         | SCS<br>Sample Clock Select for CIR <table border="1" style="margin-left: 20px;"> <tr> <td>SCS2</td><td>SCS[1]</td><td>SCS[0]</td><td>Sample Clock</td></tr> <tr> <td>0</td><td>0</td><td>0</td><td>CIR_CLK/64</td></tr> <tr> <td>0</td><td>0</td><td>1</td><td>CIR_CLK /128</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SCS2 | SCS[1] | SCS[0] | Sample Clock | 0 | 0 | 0 | CIR_CLK/64 | 0 | 0 | 1 | CIR_CLK /128 |
| SCS2           | SCS[1]     | SCS[0]      | Sample Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |        |        |              |   |   |   |            |   |   |   |              |
| 0              | 0          | 0           | CIR_CLK/64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |        |        |              |   |   |   |            |   |   |   |              |
| 0              | 0          | 1           | CIR_CLK /128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |        |        |              |   |   |   |            |   |   |   |              |

|   |   |   |              |
|---|---|---|--------------|
|   |   |   |              |
| 0 | 1 | 0 | CIR_CLK /256 |
| 0 | 1 | 1 | CIR_CLK /512 |
| 1 | 0 | 0 | CIR_CLK      |
| 1 | 0 | 1 | Reserved     |
| 1 | 1 | 0 | Reserved     |
| 1 | 1 | 1 | Reserved     |

Confidential

## 10.10. CIR Transmitter

### 10.10.1. Overview

The CIR transmitter(CIR\_TX) can transfer arbitrary wave, which is modulated with configurable carrier wave such as 38 kHz. It only uses low 8-bit of a 32-bit register, it stores with 2 register for a 16-bit number, one is high 8-bit, the other is low 8-bit.

The CIR\_TX has the following features:

- Supports industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification, Revision 2.0
- Full physical layer implementation
- 128 bytes FIFO for data buffer
- Configurable carrier frequency
- Support Interrupt and DMA
- Support DMA shake and wait mode
- Support arbitrary wave generator

### 10.10.2. Block Diagram

Figure 10-52 shows a block diagram of the CIR\_TX.



Figure 10- 52. CIR\_TX Block Diagram

### 10.10.3. Operations and Functional Descriptions

#### 10.10.3.1. External Signals

Table 10-30 describes the external signals of CIR\_TX.

Table 10- 30. CIR\_TX External Signals

| Signal  | Description                           | Type |
|---------|---------------------------------------|------|
| CIR_OUT | Consumer infrared transmitter in CPUX | I    |

#### 10.10.3.2. Clock and Reset



**Figure 10- 53. CIR\_TX Clock Description**

#### 10.10.3.3. Function Implementation

The CIR\_TX is used to generate a wave of arbitrary length and shape. It has a low demand for speed, and it can transform data into level sequence of a specific length. Every data is a byte. The Bit[7] of a byte means whether the level of a transmitting wave is high or low. The Bit[6:0] is the length of this wave. If current transmitting frequency division is 1, 0x88 is a high level of 8 cycles, 0x08 is a low level of 8 cycles. If current transmitting frequency division is 4, 0x88 is a high level of 32 cycles, 0x08 is a low level of 32 cycles.

CIR\_TX has two transmission modes, one is non-cycle transmission, and another one is cycle transmission. Non-cycle transmission is to transmit all the data in TX\_FIFO to FIFO space. Cycle transmission is to transmit all the data in FIFO, until there are no signals. The data recovery in FIFO is implemented by clearing read pointer.

#### 10.10.3.4. Timing Diagram

CIR remote control contains many protocols which designed by different manufacturers. Here to NEC protocol as an example, the CIR-TX module uses a variable pulse-width modulation technique to encompass the various formats of infrared encoding for remote-control applications. A message is started by a 9 ms AGC burst, which was used to set the gain of the earlier CIR receivers. This AGC burst is then followed by a 4.5 ms space, which is then followed by the address and command.

Bit definition: the logical “1” takes 2.25 ms to transmit, while a logical “0” is only 1.12 ms.



**Figure 10- 54. CIR One Bit Definition**

Timing for a message:



**Figure 10- 55. CIR Message Timing Diagram**

### **10.10.3.5. Operating Mode**

- IMS: Internal modulation select



- RFMC: Reference frequency of modulated carrier. FCLK, is IR\_CLK.



- DRMC: Duty ratio of modulated carrier. It can be set to 1/2, 1/3, and 1/4.
  - RCS: Reference clock select  
The data in TX\_FIFO is used to describe the pulse in Run-Length Code. The basic unit of pulse width is Reference Clock.
  - CIR Transmitter Idle Duration Counter  
It is used in cycle transmission mode. When all the data in FIFO is transmitted, signals can be transmitted after a specific time.
  - CIR Transmitter Idle Counter  
It is used to count idle duration of CIR transmitter, and it is used for software.

#### 10.10.4. Programming Guidelines



Figure 10- 56. CIR Transmitter Process

#### 10.10.5. Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|        |            |
|--------|------------|
| CIR_TX | 0x05071000 |
|--------|------------|

| Register Name | Offset | Description                                   |
|---------------|--------|-----------------------------------------------|
| CIR_TGLR      | 0x0000 | CIR Transmit Global Register                  |
| CIR_TMCR      | 0x0004 | CIR Transmit Modulation Control Register      |
| CIR_TCR       | 0x0008 | CIR Transmit Control Register                 |
| CIR_IDC_H     | 0x000C | CIR Transmit Idle Duration Threshold Register |
| CIR_IDC_L     | 0x0010 | CIR Transmit Idle Duration Threshold Register |
| CIR_TICR_H    | 0x0014 | CIR Transmit Idle Counter Register            |
| CIR_TICR_L    | 0x0018 | CIR Transmit Idle Counter Register            |
| CIR_TEL       | 0x0020 | CIR TX FIFO Empty Level Register              |
| CIR_TXINT     | 0x0024 | CIR Transmit Interrupt Control Register       |
| CIR_TAC       | 0x0028 | CIR Transmit FIFO Available Counter Register  |
| CIR_TXSTA     | 0x002C | CIR Transmit Status Register                  |
| CIR_TXT       | 0x0030 | CIR Transmit Threshold Register               |
| CIR_DMA       | 0x0034 | CIR DMA Control Register                      |
| CIR_TXFIFO    | 0x0080 | CIR Transmit FIFO Data Register               |

#### 10.10.6. Register Description

##### 10.10.6.1. 0x0000 CIR Transmitter Global Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CIR_TGLR                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                 |
| 7              | R/W        | 0x0         | IMS<br>Internal Modulation Select<br>0: the transmitting signal is not modulated<br>1: the transmitting signal is modulated internally                                                                                            |
| 6:5            | R/W        | 0x0         | DRMC<br>Duty ratio of modulated carrier is high level/low level.<br>00: low level is the one time of high level<br>01: low level is the two times of high level<br>10: low level is the three times of high level<br>11: reserved |
| 4:3            | /          | /           | /                                                                                                                                                                                                                                 |
| 2              | R/W        | 0x0         | TPPI<br>Transmit Pulse Polarity Invert<br>0: Not invert transmit pulse<br>1: Invert transmit pulse                                                                                                                                |
| 1              | R/W        | 0x0         | TR<br>Transmit Reset<br>When this bit is set, the transmitting is reset. The FIFO will be flush, the                                                                                                                              |

|   |     |     |                                                                                                                                                                                    |
|---|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | TIC filed and CSS field will be cleared during Transmit Reset. This field will automatically cleared when the Transmit Reset is finished, and the CIR transmitter will state Idle. |
| 0 | R/W | 0x0 | <p>TXEN<br/>Transmit Block Enable<br/>0: Disable the CIR Transmitter<br/>1: Enable the CIR Transmitter</p>                                                                         |

#### 10.10.6.2. 0x0004 CIR Transmitter Modulation Control Register(Default Value:0x0000\_009E)

| Offset: 0x0004 |            |             | Register Name: CIR_TMCR                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0            | R/W        | 0x9E        | <p>RFMC<br/>Reference Frequency of modulated carrier.<br/>Reference Frequency of modulated carrier based on a division of a fixed functional clock(FCLK). The range of the modulated carrier is usually 30 kHz to 60 kHz. The most consumer electronics is 38 kHz.<br/>The default modulated carrier is 38KHz when FCLK is 12 MHz.<br/>RFMC= FCLK/((N+1)*(DRMC+2)).</p> |

#### 10.10.6.3. 0x0008 CIR Transmitter Control Register(Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CIR_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7              | R/W        | 0x0         | <p>CSS<br/>Cyclical Pulse Start/Stop Control<br/>0: Stop when cleared to '0'. From start to stop, all data in FIFO must be transmitted.<br/>1: Start. Start to transmit when it is set to '1'.</p>                                                                                                                                                                                                                                                                          |
| 6:4            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3:1            | R/W        | 0x0         | <p>RCS<br/>Reference Clock Select for CIR Transmit<br/>000: CIR Transmit reference clock is ir_clk<br/>001: CIR Transmit reference clock is ir_clk/2<br/>010: CIR Transmit reference clock is ir_clk/4<br/>011: CIR Transmit reference clock is ir_clk/8<br/>100: CIR Transmit reference clock is ir_clk/64<br/>101: CIR Transmit reference clock is ir_clk/128<br/>110: CIR Transmit reference clock is ir_clk/256<br/>111: CIR Transmit reference clock is ir_clk/512</p> |

|   |     |     |                                                                                                                                                              |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R/W | 0x0 | <b>TTS</b><br>Type of the transmission signal<br>0: The transmitting wave is single non-cyclical pulse.<br>1: The transmitting wave is cyclical short-pulse. |
|---|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.10.6.4. 0x000C CIR Transmitter Idle Duration Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CIR_IDC_H                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:8           | /          | /           | /                                                                                                         |
| 3:0            | R/W        | 0x0         | <b>IDC_H</b><br>Idle Duration Counter threshold(High 4 bits)<br>Idle Duration = 128*IDC*Ts (IDC = 0~4095) |

#### 10.10.6.5. 0x0014 CIR Transmitter Idle Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: CIR_TICR_H                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                           |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                     |
| 7:0            | R          | 0x0         | <b>TIC_H</b><br>Transmit Idle Counter_H(High 8 bits)<br>Count in 128*Ts (Sample Duration, 1/Fs) when transmitter is idle, and it should be reset when the transmitter active.<br>When this counter reaches the maximum value (0xFFFF), it will stop automatically, and should not be cleared to zero. |

#### 10.10.6.6. 0x0018 CIR Transmitter Idle Counter Register(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: CIR_TICR_L                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                    |
| 7:0            | R          | 0x0         | <b>TIC_L</b><br>Transmit Idle Counter_L(Low 8 bits)<br>Count in 128*Ts (Sample Duration, 1/Fs) when transmitter is idle, and it should be reset when the transmitter active.<br>When this counter reaches the maximum value (0xFFFF), it will stop automatically, and should not be cleared to zero. |

**10.10.6.7. 0x0020 CIR Transmitter FIFO Empty Register(Default Value: 0x0000\_0000)**

| Offset: 0x0020 |            |             | Register Name: CIR_TEL                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:8           | /          | /           | /                                                                      |
| 7:0            | R/W        | 0x0         | TEL<br>TX FIFO empty Level for DRQ and IRQ.<br>TRIGGER_LEVEL = TEL + 1 |

**10.10.6.8. 0x0024 CIR Transmitter Interrupt Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x0024 |            |             | Register Name: CIR_TXINT                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:3           | /          | /           | /                                                                                                                                                                                                                             |
| 2              | R/W        | 0x0         | DRQ_EN<br>TX FIFO DMA Enable<br>0: Disable<br>1: Enable<br>When set to '1', the TX FIFO DRQ is asserted if the number of the transmitting data in the FIFO is less than the RAL. The DRQ is de-asserted when condition fails. |
| 1              | R/W        | 0x0         | TAI_EN<br>TX FIFO Available Interrupt Enable<br>0:Disable<br>1:Enable                                                                                                                                                         |
| 0              | R/W        | 0x0         | TPEI_EN<br>Transmit Packet End Interrupt Enable for Cyclical Pulse<br>0:Disable<br>1:Enable<br><br>TUI_EN<br>Transmitter FIFO Underrun Interrupt Enable for Non-cyclical Pulse<br>0: Disable<br>1: Enable                     |

**10.10.6.9. 0x0028 CIR Transmitter FIFO Available Counter Register(Default Value: 0x0000\_0080)**

| Offset: 0x0028 |            |             | Register Name: CIR_TAC                 |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:8           | /          | /           | /                                      |
| 7:0            | R          | 0x80        | TAC<br>TX FIFO Available Space Counter |

|  |  |  |                                                                                                                                                                               |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0x00: No available space in TX FIFO<br>0x01: 1 byte available space in TX FIFO<br>0x02: 2 byte available space in TX FIFO<br>...<br>0x80: 128 byte available space in TX FIFO |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.10.6.10. 0x002C CIR Transmitter Status Register(Default Value: 0x0000\_0002)

| Offset: 0x002C |            |             | Register Name: CIR_TXSTA                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3              | R          | 0x0         | <p>STCT<br/>Status of CIR Transmitter<br/>0: Idle<br/>1: Active</p> <p>This bit will automatically set when the controller begins transmit the data in the FIFO. The “1” will last when the data in the FIFO. It will automatically be cleared to “0” when all data in the FIFO is transmitted.</p> <p>The bit is for debug.</p> <p><b>Output Level of Idle state determined by level of the last data output.</b></p> |
| 2              | R          | 0x0         | <p>DRQ<br/>DMA Request Flag</p> <p>When set to ‘1’, the Tx FIFO DRQ is asserted if the number of the transmitting data in the FIFO is less than the RAL. The DRQ is de-asserted when condition fails.</p> <p>This bit is for debug.</p>                                                                                                                                                                                |
| 1              | R/W        | 0x1         | <p>TAI<br/>TX FIFO Available Interrupt Flag<br/>0: TX FIFO not available by its level<br/>1: TX FIFO available by its level</p> <p>This bit can be cleared by software writing ‘1’.</p>                                                                                                                                                                                                                                |
| 0              | R/W        | 0x0         | <p>TPE<br/>Transmitter Packet End Flag for Cyclical Pulse<br/>0: Transmissions of address, control and data fields not completed<br/>1: Transmissions of address, control and data fields completed</p> <p>TUR<br/>Transmitter FIFO Under Run Flag for Non-cyclical Pulse<br/>0: No transmitter FIFO under run<br/>1: Transmitter FIFO under run</p> <p>This bit is cleared by writing a ‘1’.</p>                      |

**10.10.6.11. 0x0030 CIR Transmitter Threshold Register(Default Value: 0x0000\_0000)**

| Offset: 0x0030 |            |             | Register Name: CIR_TXT                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:8           | /          | /           | /                                                                                                                                                                                              |
| 7:0            | R/W        | 0x0         | NCTT<br>Non-cyclical Pulse Transmit Threshold<br>The controller will trigger transmitting the data in the FIFO when the data byte number has reached the Transmit Threshold set in this field. |

**10.10.6.12. 0x0034 CIR Transmitter DMA Control Register(Default Value: 0x0000\_00A5)**

| Offset: 0x0034 |            |             | Register Name: CIR_DMA_CTL                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:8           | /          | /           | /                                                                                    |
| 7:0            | R/W        | 0xA5        | DMA Handshake Configuration<br>0xA5: DMA wait cycle mode<br>0xEA: DMA handshake mode |

**10.10.6.13. 0x0080 CIR Transmitter FIFO Data Register(Default Value: 0x0000\_0000)**

| Offset: 0x0080 |            |             | Register Name: CIR_TXFIFO                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:8           | /          | /           | /                                                                                                                                                     |
| 7:0            | W          | 0x0         | Transmit Byte FIFO<br>When the transmitting is trigger, the data in the FIFO will be transmitted until the data number has been transmitted finished. |

## 10.11. PWM

### 10.11.1. Overview

The PWM controller has 4 PWM channels(PWM0,PWM1,PWM2,PWM3), and divides to 2 PWM pairs:PWM01 pair, PWM23 pair. PWM01 pair consists of PWM0 and PWM1, PWM23 pair consists of PWM2 and PWM3.

The PWM has the following features:

- 4 PWM channels(2 PWM pairs)
- Supports pulse(configurable pulse number),cycle and complementary pair output
- Supports capture input
- Programming deadzone output
- Build-in the programmable dead-time generator, controllable dead-time
- Three kinds of output waveform: continuous waveform, pulse waveform and complementary pair
- Output frequency range: 0~ 24 MHz/100 MHz
- Various duty-cycle: 0% ~100%
- Minimum resolution: 1/65536
- Interrupt generation of PWM output and capture input

### 10.11.2. Block Diagram



Figure 10- 57. PWM Block Diagram

Each PWM pair consists of 1 clock module, 2 timer logic module and 1 programmable dead-time generator.

### 10.11.3. Operations and Functional Descriptions

#### 10.11.3.1. External Signals

Table 10-31 describes the external signals of the PWM.

**Table 10- 31. PWM External Signals**

| Signal | Description                 | Type |
|--------|-----------------------------|------|
| PWM0   | Pulse Width Module Channel0 | I/O  |
| PWM1   | Pulse Width Module Channel1 | I/O  |
| PWM2   | Pulse Width Module Channel2 | I/O  |
| PWM3   | Pulse Width Module Channel3 | I/O  |

#### 10.11.3.2. Typical Application

- Suitable for display device, such as LCD
- Suitable for electric motor control

#### 10.11.3.3. Clock Controller

Using PWM01 as an example, the clock controller diagram is as follows. The clock controller diagram of other PWM pairs is the same as PWM01.



**Figure 10- 58. PWM01 Clock Controller Diagram**

The clock controller of each PWM pair(for example: PWM01) includes clock source select(PWM01\_CLK\_SRC\_SEL), the first-level exponent divider (PWM01\_CLK\_DIV\_M), the second-level count divider(PRESCAL\_K), clock source bypass(CLK\_SRC\_BYPASS) and clock switch(PWM01\_CLK\_GATING).

The clock sources of PWM have OSC24M and APB1 Bus. OSC24M comes from external high frequency oscillator, APB1 is APB1 bus clock, usually is 100 MHz.

The clock source bypass function is that clock source directly accesses PWM output, the PWM output waveform is the waveform of clock controller output. The BYPASS gridlines in the above figure indicates clock source bypass function, the details about implement, please see Figure 10-59.

#### 10.11.3.4. PWM Output

Using PWM01 as an example, Figure 10-59 indicates PWM01 output logic module diagram. Other PWM pairs logic module diagrams are the same as PWM01.



Figure 10- 59. PWM01 Output Logic Module Diagram

The timer logic module of PWM(PWM\_TIMER\_LOGIC) consists of one 16-bit up-counter(PCNTR) and three 16-bit parameters(PWM\_ENTIRE\_CYCLE, PWM\_ACTIVE\_CYCLE, PWM\_CNTSTART). The PWM\_ENTIRE\_CYCLE is used to control PWM cycle, the PWM\_ACTIVE\_CYCLE is used to control duty-cycle, the PWM\_CNTSTART is used to control output phase(multi-channels synchronization work requirements).

The PWM\_ENTIRE\_CYCLE and the PWM\_ACTIVE\_CYCLE support cache loading, after PWM output is enabled, the register values of the PWM\_ENTIRE\_CYCLE and the PWM\_ACTIVE\_CYCLE can be changed anytime, the changed value caches into the cache register. When PCNTR counter outputs a period of PWM waveform, the value of the cache register can be updated for PCNTR control. Cache-loading is good to avoid unstable PWM output waveform with burred feature when updating the values of the PWM\_ENTIRE\_CYCLE and the PWM\_ACTIVE\_CYCLE.

PWM supports cycle and pulse waveform output.

**Cycle mode:** PWM outputs the setting PWM waveform continually, that is, the output waveform is a continuous PWM square wave.

**Pulse mode:** After setting PWM\_PUL\_CNT parameter, PWM outputs (PWM\_PULNUM+1) periods of PWM waveform, that is, the waveform with several pulses are output.

### 10.11.3.5. Period, Duty-cycle and Phase

The period, duty-cycle and phase of PWM output waveform are decided by the PCNTR, PWM\_ENTIRE\_CYCLE, PWM\_ACT\_CYCLE and PWM\_CNTSTART. The rules are as follows.

- $\text{PCNTR} = (\text{PCNTR} == \text{PWM\_ENTIRE\_CYCLE}) ? 0 : \text{PCNTR} + 1$
- PCNTR starts to count by PWM\_CNTSTART, the counter of a PWM period is ( $\text{PWM\_ENTIRE\_CYCLE} + 1$ ).
- $\text{PCNTR} > (\text{PWM\_ENTIRE\_CYCLE} - \text{PWM\_ACT\_CYCLE})$ , output “active state”
- $\text{PCNTR} \leq (\text{PWM\_ENTIRE\_CYCLE} - \text{PWM\_ACT\_CYCLE})$ , output “~ (active state)”

#### (1) Active state of PWM0 channel is high level (PCR0.PWM\_ACT\_STA = 1)

When  $\text{PCNTR0} > (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 1(high level).

When  $\text{PCNTR0} \leq (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 0(low level).

The formula of PWM output period and duty-cycle is as follows.

$$T_{\text{period}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1)$$

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * \text{PPR0.PWM\_ACT\_CYCLE}$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1 - \text{PPR0.PWM\_ACT\_CYCLE})$$

$$\text{Duty-cycle} = (\text{high level time}) / (\text{1 period time}) = T_{\text{high-level}} / T_{\text{period}}$$



Figure 10-60. The Period and Duty-cycle of PWM0 High Level Active State

#### (2) Active state of PWM0 channel is low level (PCR0.PWM\_ACT\_STA = 0)

When  $\text{PCNTR0} > (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 0.

When  $\text{PCNTR0} \leq (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 1.

The formula of PWM output period and duty-cycle is as follows.

$$T_{\text{period}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1)$$

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1 - \text{PPR0.PWM\_ACT\_CYCLE})$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * \text{PPR0.PWM\_ACT\_CYCLE}$$

$$\text{Duty-cycle} = (\text{low level time}) / (\text{1 period time}) = T_{\text{low-level}} / T_{\text{period}}$$



Figure 10- 61. The Period and Duty-cycle of PWM0 Low Level Active State

The counter of PCNTR starts from 0 by default, it can output the pulse control of the waveform by setting PWM\_CNTSTART. The figure is as follows.



Figure 10- 62. The Phase of PWM0 High Level Active State

#### 10.11.3.6. Pulse Mode and Cycle Mode

PWM output supports pulse mode and cycle mode. PWM in pulse mode outputs one pulse waveform, but PWM in cycle mode outputs continuous waveform. Figure 10-63 shows the PWM output waveform in pulse mode and cycle mode.



**Figure 10- 63. PWM0 Output Waveform in Pulse Mode and Cycle Mode**

Each channel of PWM module supports the PWM output of pulse mode and cycle mode, the active state of PWM output waveform can be programmed to control.

When PCRO.PWM\_MODE is 0, PWM0 outputs in cycle mode. When PCRO.PWM\_MODE is 1, PWM0 outputs in pulse mode.

Specifically, in pulse mode, after PWM0 channel enabled, PCRO.PWM\_PUL\_START need be set to 1 when PWM0 need output pulse waveform, after completed output, PCRO.PWM\_PUL\_START can be cleared to 0 by hardware. The next setting 1 can be operated after PCRO.PWM\_PUL\_START is cleared.

#### 10.11.3.7. Complementary Pair Output

Every PWM pair supports complementary pair output and PWM pair with dead-time. Figure 10-64 shows the complementary pair output of PWM01.



**Figure 10- 64. PWM01 Complementary Pair Output**

The complementary pair output needs to satisfy the following four conditions:

- PWM0 and PWM1 have the same clock divider, frequency, duty-cycle, pulse
- PWM0 and PWM1 have opposite active state
- Enable the clock gating of PWM0 and PWM1 at the same time
- Enable the waveform output of PWM0 and PWM1 at the same time

#### 10.11.3.8. Dead-time Generator

Every PWM pair has a programmable dead-time generator. When the dead-time function of PWM pair enabled, PWM01 pair outputs a pair of PWM waveforms that insert dead-time, PWM01 pair output waveform is decided by PWM0 timer logic module and DeadZone Generator01. Figure 10-65 shows the output waveform.



Figure 10- 65. PWM01 Pair Waveform Before/After Insert Dead-time

The PWM waveform before the insertion of dead-time indicates a complementary waveform pair of non-inserted dead-time in Dead Zone Generator 01.

The PWM waveform after the insertion of dead-time indicates a non-complementary PWM waveform pair inserted dead-time in a complementary waveform pair of Dead Zone Generator 01. The PWM waveform pair at last outputs to PWM0 pin and PWM1 pin.

For complementary pair of Dead Zone Generator 01, the principle of inserting dead-time is that to insert dead-time as soon as the rising edge came. If high level time for mark② in the above figure is less than dead-time, then dead-time will override the high level. The setting of dead-time need consider the period and duty-cycle of output waveform. Dead-time formula is defined as follows:

$$\text{Dead-time} = (\text{PWM01_CLK} / \text{PWM0_PRESCALE\_K})^{-1} * \text{PDZINTV01}$$

### 10.11.3.9. PWM Group Mode

Using PWM Group0 as an example. The same group of PWM channel is selected to work by PGR0.CS; the same PWM\_ENTIRE\_CYCLE, PWM\_ACTIVE\_CYCLE are set by the same clock configuration; the different PWM\_CNTSTART can output PWM group signals with same duty-cycle, different phase.



Figure 10- 66. Group 0~3 PWM Signal Output

### 10.11.3.10. Capture Input



Figure 10-67. PWM01 Capture Logic Module Diagram

Besides the timer logic module of every PWM channel generates PWM output, it can be used to capture rising edge and falling edge of the external clock. Using PWM0 channel as an example, PWM0 channel has one **CFLR0** and one **CRLR0** for capturing up-counter value in falling edge and rising edge, respectively. You can calculate the period of external clock by **CFLR0** and **CRLR0**.

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CRLR0}$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CFLR0}$$

$$T_{\text{period}} = T_{\text{high-level}} + T_{\text{low-level}}$$



Figure 10- 68. PWM0 Channel Capture Timing

When the capture input function of PWM0 channel is enabled, the PCNTR of PWM0 channel starts to work.

When the timer logic module of PWM0 captures one rising edge, the current value of up-counter is locked to **CRLR0**, and **CCRO.CRLF** is set to 1. If **CRIEO** is 1, then **CRISO** is set to 1, PWM0 channel sends interrupt request, and the up-counter is loaded to 0 and continues to count. If **CRIEO** is 0, the timer logic module of PWM0 captures rising edge, **CRISO** can not be set to 1, the up-counter is not loaded to 0.

When the timer logic module of PWM0 captures one falling edge, the current value of **PCNTR** is locked to **CFLR0**, and **CCRO.CFLF** is set to 1. If **CFIEO** is 1, then **CFISO** is set to 1, PWM0 channel sends interrupt request, and the up-counter is loaded to 0 and continues to count. If **CFIEO** is 0, the timer logic module of PWM0 captures falling edge, **CFISO** can not be set to 1, the up-counter is not loaded to 0.

#### 10.11.3.11. Interrupt

PWM supports interrupt generation when PWM channel is configured to PWM output or capture input .

For PWM output function, when one period of PWM waveform is output in cycle mode, the PIS of the corresponding PWM channel is set to 1; when (PWM\_PULNUM+1) periods of PWM waveform is outputted in pulse mode, the PIS of the corresponding PWM channel is set to 1.



#### NOTE

**The PIS bit is set to 1 automatically by hardware and cleared by software.**

For capture input function, when the timer logic module of the capture channel0 captures rising edge, and **CRIEO** is 1, then **CRISO** is set to 1; when the timer logic module of the capture channel0 captures falling edge, and **CFIEO** is 1, then **CFISO** is set to 1.

#### 10.11.4. Working Mode

The following working mode takes PWM01 as an example, other PWM pairs and PWM01 are consistent.

##### 10.11.4.1. Clock Configuration

- (1) PWM gating: When using PWM, write 1 to **PCGR[PWMx\_CLK\_GATING]**.
- (2) PWM clock source select: Set **PCCR01[PWM01\_CLK\_SRC]** to select OSC24M or APB1 clock.
- (3) PWM clock divider: Set **PCCR01[PWM01\_CLK\_DIV\_M]** to select different frequency division coefficient (1/2/4/8/16/32/64/128/256).
- (4) PWM clock bypass: Set **PCGR[PWM\_CLK\_SRC\_BYPASS\_TO\_PWM]** to 1, output the PWM clock after the secondary frequency division to the corresponding PWM output pin.
- (5) PWM internal clock configuration: Set **PCR[PWM\_PRESCAL\_K]** to select any frequency division coefficient from 1 to 256.



##### NOTE

For the channel of complementary output and group mode, firstly, set the same clock configurations(clock source selects APB1, clock division configures the same division factor); secondly, open clock gating at the same time; thirdly, configure PWM parameters; finally, enable PWM output at the same time to ensure each channel sync.

Because PWM pair has the same first level clock division and gating, we suggest that the two channels of the same PWM pair can not subject to two groups, if must allocate based on this way, the first level of clock division of the channel used by all groups needs to set to the same coefficient and open gating at the same time. And the total module needs be reset when group mode regroups.

##### 10.11.4.2. PWM Configuration

- (1) PWM mode: Set **PCR[PWM\_MODE]** to select cycle mode or pulse mode, if pulse mode, **PWM\_PUL\_NUM** needs be configured.
- (2) PWM active level: Set **PCR[PWM\_ACT\_STA]** to select low level or high level.
- (3) PWM duty-cycle: Configure **PPR[PWM\_ENTIRE\_CYCLE]** and **PPR[PWM\_ACT\_CYCLE]** after clock gating is opened.
- (4) Enable PWM: Configure PER to select the corresponding PWM enable bit; when selecting pulse mode, **PCR[PWM\_PUL\_START]** needs be enabled.

##### 10.11.4.3. Deadzone Control

- (1) Deadzone initial value: Set **PDZCR01[PDZINTV01]**.
- (2) Deaszone enable: Set **PDZCR01[PWM01\_DZ\_CN]**.

##### 10.11.4.4. Capture Input

- (1) Capture enable: Configure CER to enable the corresponding channel.
- (2) Capture mode: Configure **CCR[CRLF]** and **CCR[CFLF]** to select rising edge capture or falling edge capture, configure

CCR[CAPINV] to select whether the input signal does reverse processing.

### 10.11.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| PWM         | 0x0300A000   |
| R_PWM       | 0x07020C00   |

| Register Name | Offset                        | Description                        |
|---------------|-------------------------------|------------------------------------|
| PIER          | 0x0000                        | PWM IRQ Enable Register            |
| PISR          | 0x0004                        | PWM IRQ Status Register            |
| CIER          | 0x0010                        | Capture IRQ Enable Register        |
| CISR          | 0x0014                        | Capture IRQ Status Register        |
| PCCR01        | 0x0020                        | PWM01 Clock Configuration Register |
| PCCR23        | 0x0024                        | PWM23 Clock Configuration Register |
| PCGR          | 0x0040                        | PWM Clock Gating Register          |
| PDZCR01       | 0x0060                        | PWM01 Dead Zone Control Register   |
| PDZCR23       | 0x0064                        | PWM23 Dead Zone Control Register   |
| PER           | 0x0080                        | PWM Enable Register                |
| PGRO          | 0x0090                        | PWM Group0 Register                |
| PGR1          | 0x0094                        | PWM Group1 Register                |
| PGR2          | 0x0098                        | PWM Group2 Register                |
| PGR3          | 0x009C                        | PWM Group3 Register                |
| CER           | 0x00C0                        | Capture Enable Register            |
| PCR           | 0x0100+0x0000+N*0x0020(N=0~3) | PWM Control Register               |
| PPR           | 0x0100+0x0004+N*0x0020(N=0~3) | PWM Period Register                |
| PCNTR         | 0x0100+0x0008+N*0x0020(N=0~3) | PWM Count Register                 |
| PPCNTR        | 0x0100+0x000C+N*0x0020(N=0~3) | PWM Pulse Count Register           |
| CCR           | 0x0100+0x0010+N*0x0020(N=0~3) | Capture Control Register           |
| CRLR          | 0x0100+0x0014+N*0x0020(N=0~3) | Capture Rise Lock Register         |
| CFLR          | 0x0100+0x0018+N*0x0020(N=0~3) | Capture Fall Lock Register         |

### 10.11.6. Register Description

#### 10.11.6.1. 0x0000 PWM IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0000 |            |             | Register Name: PIER                   |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:20         | /          | /           | /                                     |
| 19            | R/W        | 0x0         | PGIE3<br>PWM Group 3 Interrupt Enable |

|      |     |     |                                                                                                                    |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------|
|      |     |     | 0: Disable<br>1: Enable                                                                                            |
| 18   | R/W | 0x0 | PGIE2<br>PWM Group 2 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 17   | R/W | 0x0 | PGIE1<br>PWM Group 1 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 16   | R/W | 0x0 | PGIE0<br>PWM Group 0 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 15:4 | /   | /   | /                                                                                                                  |
| 3    | R/W | 0x0 | PCIE3<br>PWM Channel 3 Interrupt Enable<br>0: PWM channel 3 interrupt disable<br>1: PWM channel 3 interrupt enable |
| 2    | R/W | 0x0 | PCIE2<br>PWM Channel 2 Interrupt Enable<br>0: PWM channel 2 interrupt disable<br>1: PWM channel 2 interrupt enable |
| 1    | R/W | 0x0 | PCIE1<br>PWM Channel 1 Interrupt Enable<br>0: PWM channel 1 interrupt disable<br>1: PWM channel 1 interrupt enable |
| 0    | R/W | 0x0 | PCIE0<br>PWM Channel 0 Interrupt Enable<br>0: PWM channel 0 interrupt disable<br>1: PWM channel 0 interrupt enable |

#### 10.11.6.2. 0x0004 PWM IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:0x0004 |            |             | Register Name: PISR                   |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:20         | /          | /           | /                                     |
| 19            | R/W1C      | 0x0         | PGIS3<br>PWM Group 3 Interrupt Status |
| 18            | R/W1C      | 0x0         | PGIS2<br>PWM Group 2 Interrupt Status |
| 17            | R/W1C      | 0x0         | PGIS1<br>PWM Group 1 Interrupt Status |

|      |       |     |                                                                                                                                                                                                                                                                                                                                                       |
|------|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16   | R/W1C | 0x0 | PGISO<br>PWM Group 0 Interrupt Status                                                                                                                                                                                                                                                                                                                 |
| 15:4 | /     | /   | /                                                                                                                                                                                                                                                                                                                                                     |
| 3    | R/W1C | 0x0 | PIS3<br>PWM Channel 3 Interrupt Status<br>When the counter of PWM channel 3 reaches Entire Cycle Value, this bit is set to 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 3 interrupt is not pending.<br>Reads 1: PWM channel 3 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 3 interrupt status. |
| 2    | R/W1C | 0x0 | PIS2<br>PWM Channel 2 Interrupt Status<br>When the counter of PWM channel 2 reaches Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 2 interrupt is not pending.<br>Reads 1: PWM channel 2 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 2 interrupt status.    |
| 1    | R/W1C | 0x0 | PIS1<br>PWM Channel 1 Interrupt Status<br>When the counter of PWM channel 1 reaches Entire Cycle Value, this bit is set to 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 1 interrupt is not pending.<br>Reads 1: PWM channel 1 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 1 interrupt status. |
| 0    | R/W1C | 0x0 | PISO<br>PWM Channel 0 Interrupt Status<br>When the counter of PWM channel 0 reaches Entire Cycle Value, this bit is set to 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 0 interrupt is not pending.<br>Reads 1: PWM channel 0 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 0 interrupt status. |

#### 10.11.6.3. 0x0010 PWM Capture IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0010 |            |             | Register Name: CIER                                                                                                          |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:8          | /          | /           | /                                                                                                                            |
| 7             | R/W        | 0x0         | CFIE3<br>If the bit is set to 1, when capturing channel 3 captures falling edge, it generates a capturing channel 3 pending. |

|   |     |     |                                                                                                                                                                                                                                         |
|---|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: Capturing channel 3 fall lock interrupt disable<br>1: Capturing channel 3 fall lock interrupt enable                                                                                                                                 |
| 6 | R/W | 0x0 | CRIE3<br>If the bit is set to 1, when capturing channel 3 captures rising edge, it generates a capturing channel 3 pending.<br>0: Capturing channel 3 rise lock interrupt disable<br>1: Capturing channel 3 rise lock interrupt enable  |
| 5 | R/W | 0x0 | CFIE2<br>If the bit is set to 1, when capturing channel 2 captures falling edge, it generates a capturing channel 2 pending.<br>0: Capturing channel 2 fall lock interrupt disable<br>1: Capturing channel 2 fall lock interrupt enable |
| 4 | R/W | 0x0 | CRIE2<br>If the bit is set to 1, when capturing channel 2 captures rising edge, it generates a capturing channel 2 pending.<br>0: Capturing channel 2 rise lock interrupt disable<br>1: Capturing channel 2 rise lock interrupt enable  |
| 3 | R/W | 0x0 | CFIE1<br>If the bit is set to 1, when capturing channel 1 captures falling edge, it generates a capturing channel 1 pending.<br>0: Capturing channel 1 fall lock interrupt disable<br>1: Capturing channel 1 fall lock interrupt enable |
| 2 | R/W | 0x0 | CRIE1<br>If the bit is set to 1, when capturing channel 1 captures rising edge, it generates a capturing channel 1 pending.<br>0: Capturing channel 1 rise lock interrupt disable<br>1: Capturing channel 1 rise lock interrupt enable  |
| 1 | R/W | 0x0 | CFIE0<br>If the bit is set to 1, when capturing channel 0 captures falling edge, it generates a capturing channel 0 pending.<br>0: Capturing channel 0 fall lock interrupt disable<br>1: Capturing channel 0 fall lock interrupt enable |
| 0 | R/W | 0x0 | CRIE0<br>If the bit is set to 1, when capturing channel 0 captures rising edge, it generates a capturing channel 0 pending.<br>0: Capturing channel 0 rise lock interrupt disable<br>1: Capturing channel 0 rise lock interrupt enable  |

#### 10.11.6.4. 0x0014 PWM Capture IRQ Status Register (Default Value: 0x0000\_0000) ?

| Offset:0x0014 |            |             | Register Name: CISR                                             |
|---------------|------------|-------------|-----------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                     |
| 31            | R/W1C      | 0x0         | <b>CFISF</b><br>Capture channel F falling lock interrupt status |

|    |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | When capture channel F captures falling edge, if capture channel F fall lock interrupt (CFIEF) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel F interrupt is not pending.<br>1: Capture channel F interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel F interrupt status.                                                                    |
| 30 | R/W1C | 0x0 | <b>CRISF</b><br>Capture channel F rising lock interrupt status<br>When capture channel F captures rising edge, if capture channel F rise lock interrupt (CRIEF) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel F interrupt is not pending.<br>1: Capture channel F interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel F interrupt status.   |
| 29 | R/W1C | 0x0 | <b>CFISE</b><br>Capture channel E falling lock interrupt status<br>When capture channel E captures falling edge, if capture channel E fall lock interrupt (CFIEE) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel E interrupt is not pending.<br>1: Capture channel E interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel E interrupt status. |
| 28 | R/W1C | 0x0 | <b>CRISE</b><br>Capture channel E rising lock interrupt status<br>When capture channel E captures rising edge, if capture channel E rise lock interrupt (CRIEE) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel E interrupt is not pending.<br>1: Capture channel E interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel E interrupt status.   |
| 27 | R/W1C | 0x0 | <b>CFISD</b><br>Capture channel D falling lock interrupt status<br>When capture channel D captures falling edge, if capture channel D fall lock interrupt (CFIED) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel D interrupt is not pending.<br>1: Capture channel D interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel D interrupt status. |
| 26 | R/W1C | 0x0 | <b>CRISD</b><br>Capture channel D rising lock interrupt status                                                                                                                                                                                                                                                                                                                                                              |

|    |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | When capture channel D captures rising edge, if capture channel D rise lock interrupt (CRIED) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel D interrupt is not pending.<br>1: Capture channel D interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel D interrupt status.                                                                     |
| 25 | R/W1C | 0x0 | <b>CFISC</b><br>Capture channel C falling lock interrupt status<br>When capture channel C captures falling edge, if capture channel C fall lock interrupt (CFIEC) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel C interrupt is not pending.<br>1: Capture channel C interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel C interrupt status. |
| 24 | R/W1C | 0x0 | <b>CRISC</b><br>Capture channel C rising lock interrupt status<br>When capture channel C captures rising edge, if capture channel C rise lock interrupt (CRIEC) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel C interrupt is not pending.<br>1: Capture channel C interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel C interrupt status.   |
| 23 | R/W1C | 0x0 | <b>CFISB</b><br>Capture channel B falling lock interrupt status<br>When capture channel B captures falling edge, if capture channel B fall lock interrupt (CFIEB) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel B interrupt is not pending.<br>1: Capture channel B interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel B interrupt status. |
| 22 | R/W1C | 0x0 | <b>CRISB</b><br>Capture channel B rising lock interrupt status<br>When capture channel B captures rising edge, if capture channel B rise lock interrupt (CRIEB) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel B interrupt is not pending.<br>1: Capture channel B interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel B interrupt status.   |
| 21 | R/W1C | 0x0 | <b>CFISA</b><br>Capture channel A falling lock interrupt status                                                                                                                                                                                                                                                                                                                                                             |

|    |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | When capture channel A captures falling edge, if capture channel A fall lock interrupt (CFIEA) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel A interrupt is not pending.<br>1: Capture channel A interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel A interrupt status.                                                                    |
| 20 | R/W1C | 0x0 | <b>CRISA</b><br>Capture channel A rising lock interrupt status<br>When capture channel A captures rising edge, if capture channel A rise lock interrupt (CRIEA) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel A interrupt is not pending.<br>1: Capture channel A interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel A interrupt status.   |
| 19 | R/W1C | 0x0 | <b>CFIS9</b><br>Capture channel 9 falling lock interrupt status<br>When capture channel 9 captures falling edge, if capture channel 9 fall lock interrupt (CFIE9) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 9 interrupt is not pending.<br>1: Capture channel 9 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 9 interrupt status. |
| 18 | R/W1C | 0x0 | <b>CRIS9</b><br>Capture channel 9 rising lock interrupt status<br>When capture channel 9 captures rising edge, if capture channel 9 rise lock interrupt (CRIE9) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 9 interrupt is not pending.<br>1: Capture channel 9 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 9 interrupt status.   |
| 17 | R/W1C | 0x0 | <b>CFIS8</b><br>Capture channel 8 falling lock interrupt status<br>When capture channel 8 captures falling edge, if capture channel 8 fall lock interrupt (CFIE8) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 8 interrupt is not pending.<br>1: Capture channel 8 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 8 interrupt status. |
| 16 | R/W1C | 0x0 | <b>CRIS8</b><br>Capture channel 8 rising lock interrupt status                                                                                                                                                                                                                                                                                                                                                              |

|    |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | When capture channel 8 captures rising edge, if capture channel 8 rise lock interrupt (CRIE8) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 8 interrupt is not pending.<br>1: Capture channel 8 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 8 interrupt status.                                                                     |
| 15 | R/W1C | 0x0 | <b>CFIS7</b><br>Capture channel 7 falling lock interrupt status<br>When capture channel 7 captures falling edge, if capture channel 7 fall lock interrupt (CFIE7) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 7 interrupt is not pending.<br>1: Capture channel 7 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 7 interrupt status. |
| 14 | R/W1C | 0x0 | <b>CRIS7</b><br>Capture channel 7 rising lock interrupt status<br>When capture channel 7 captures rising edge, if capture channel 7 rise lock interrupt (CRIE7) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 7 interrupt is not pending.<br>1: Capture channel 7 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 7 interrupt status.   |
| 13 | R/W1C | 0x0 | <b>CFIS6</b><br>Capture channel 6 falling lock interrupt status<br>When capture channel 6 captures falling edge, if capture channel 6 fall lock interrupt (CFIE6) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 6 interrupt is not pending.<br>1: Capture channel 6 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 6 interrupt status. |
| 12 | R/W1C | 0x0 | <b>CRIS6</b><br>Capture channel 6 rising lock interrupt status<br>When capture channel 6 captures rising edge, if capture channel 6 rise lock interrupt (CRIE6) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 6 interrupt is not pending.<br>1: Capture channel 6 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 6 interrupt status.   |
| 11 | R/W1C | 0x0 | <b>CFIS5</b><br>Capture channel 5 falling lock interrupt status                                                                                                                                                                                                                                                                                                                                                             |

|    |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |       |     | When capture channel 5 captures falling edge, if capture channel 5 fall lock interrupt (CFIE5) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 5 interrupt is not pending.<br>1: Capture channel 5 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 5 interrupt status.                                                                               |
| 10 | R/W1C | 0x0 | <b>CRIS5</b><br>Capture channel 5 rising lock interrupt status<br>When capture channel 5 captures rising edge, if capture channel 5 rise lock interrupt (CRIE5) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 5 interrupt is not pending.<br>1: Capture channel 5 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 5 interrupt status.              |
| 9  | R/W1C | 0x0 | <b>CFIS4</b><br>Capture channel 4 falling lock interrupt status<br>When capture channel 4 captures falling edge, if capture channel 4 fall lock interrupt (CFIE4) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 4 interrupt is not pending.<br>1: Capture channel 4 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 4 interrupt status.            |
| 8  | R/W1C | 0x0 | <b>CRIS4</b><br>Capture channel 4 rising lock interrupt status<br>When capture channel 4 captures rising edge, if capture channel 4 rise lock interrupt (CRIE4) is enabled, this bit is set to 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 4 interrupt is not pending.<br>1: Capture channel 4 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 4 interrupt status.              |
| 7  | R/W1C | 0x0 | CFIS3<br>Capture channel 3 falling lock interrupt status.<br>When capture channel 3 captures falling edge, if capture channel 3 fall lock interrupt ( <b>CFIE3</b> ) is enabled, this bit is set 1 by hardware.Writing 1 to clear this bit.<br>Reads 0: Capture channel 3 interrupt is not pending.<br>Reads 1: Capture channel 3 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 3 interrupt status. |
| 6  | R/W1C | 0x0 | CRIS3<br>Capture channel 3 rising lock interrupt status.                                                                                                                                                                                                                                                                                                                                                                               |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | When capture channel 3 captures rising edge, if capture channel 3 rise lock interrupt ( <b>CRIE3</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 3 interrupt is not pending.<br>Reads 1: Capture channel 3 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 3 interrupt status.                                                               |
| 5 | R/W1C | 0x0 | CFIS2<br>Capture channel 2 falling lock interrupt status.<br>When capture channel 2 captures falling edge, if capture channel 2 fall lock interrupt ( <b>CFIE2</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 2 interrupt is not pending.<br>Reads 1: Capture channel 2 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 2 interrupt status. |
| 4 | R/W1C | 0x0 | CRIS2<br>Capture channel 2 rising lock interrupt status.<br>When capture channel 2 captures rising edge, if capture channel 2 rise lock interrupt ( <b>CRIE2</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 2 interrupt is not pending.<br>Reads 1: Capture channel 2 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 2 interrupt status.   |
| 3 | R/W1C | 0x0 | CFIS1<br>Capture channel 1 falling lock interrupt status.<br>When capture channel 1 captures falling edge, if capture channel 1 fall lock interrupt ( <b>CFIE1</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 1 interrupt is not pending.<br>Reads 1: Capture channel 1 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 1 interrupt status. |
| 2 | R/W1C | 0x0 | CRIS1<br>Capture channel 1 rising lock interrupt status.<br>When capture channel 1 captures rising edge, if capture channel 1 rise lock interrupt ( <b>CRIE1</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 1 interrupt is not pending.<br>Reads 1: Capture channel 1 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 1 interrupt status.   |
| 1 | R/W1C | 0x0 | CFISO<br>Capture channel 0 falling lock interrupt status.                                                                                                                                                                                                                                                                                                                                                                               |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | When capture channel 0 captures falling edge, if capture channel 0 fall lock interrupt ( <b>CFIE0</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 0 interrupt is not pending.<br>Reads 1: Capture channel 0 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 0 interrupt status.                                                            |
| 0 | R/W1C | 0x0 | CRISO<br>Capture channel 0 rising lock interrupt status.<br>When capture channel 0 captures rising edge, if capture channel 0 rise lock interrupt ( <b>CRIEO</b> ) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: Capture channel 0 interrupt is not pending.<br>Reads 1: Capture channel 0 interrupt is pending.<br>Writes 0: no effect.<br>Writes 1: Clear capture channel 0 interrupt status. |

#### 10.11.6.5. 0x0020 PWM01 Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0020 |            |             | Register Name: PCCR01                                                                                                                                                          |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:9          | /          | /           | /                                                                                                                                                                              |
| 8:7           | R/W        | 0x0         | PWM01_CLK_SRC<br>Select PWM01 Clock Source<br>00: OSC24M<br>01: APB1<br>Others: Reserved                                                                                       |
| 6:4           | /          | /           | /                                                                                                                                                                              |
| 3:0           | R/W        | 0x0         | PWM01_CLK_DIV_M<br>PWM01 Clock Divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: Reserved |

**10.11.6.6. 0x0024 PWM23 Clock Configuration Register (Default Value: 0x0000\_0000)**

| Offset:0x0024 |            |             | Register Name: PCCR23                                                                                                                                                   |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9          | /          | /           | /                                                                                                                                                                       |
| 8:7           | R/W        | 0x0         | PWM23_CLK_SRC_SEL<br>Select PWM23 Clock Source<br>00: OSC24M<br>01: APB1<br>Others: Reserved                                                                            |
| 6:4           | /          | /           | /                                                                                                                                                                       |
| 3:0           | R/W        | 0x0         | PWM23_CLK_DIV_M<br>PWM23 Clock Divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

**10.11.6.7. 0x0040 PWM Clock Gating Register (Default Value: 0x0000\_0000)**

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:20          | /          | /           | /                                                                                                     |
| 19             | R/W        | 0x0         | PWM3_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM3 output<br>0: not bypass<br>1: bypass |
| 18             | R/W        | 0x0         | PWM2_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM2 output<br>0: not bypass<br>1: bypass |
| 17             | R/W        | 0x0         | PWM1_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM1 output<br>0: not bypass<br>1: bypass |
| 16             | R/W        | 0x0         | PWM0_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM0 output<br>0: not bypass              |

|      |     |     |                                                                |
|------|-----|-----|----------------------------------------------------------------|
|      |     |     | 1: bypass                                                      |
| 15:4 | /   | /   | /                                                              |
| 3    | R/W | 0x0 | PWM3_CLK_GATING<br>Gating clock for PWM3<br>0: Mask<br>1: Pass |
| 2    | R/W | 0x0 | PWM2_CLK_GATING<br>Gating clock for PWM2<br>0: Mask<br>1: Pass |
| 1    | R/W | 0x0 | PWM1_CLK_GATING<br>Gating clock for PWM1<br>0: Mask<br>1: Pass |
| 0    | R/W | 0x0 | PWM0_CLK_GATING<br>Gating clock for PWM0<br>0: Mask<br>1: Pass |

#### 10.11.6.8. 0x0060 PWM01 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: PDZCR01                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:16          | /          | /           | /                                                                                     |
| 15:8           | R/W        | 0x0         | PDZINTV01<br>PWM01 Dead Zone Interval Value                                           |
| 7:1            | /          | /           | /                                                                                     |
| 0              | R/W        | 0x0         | PWM01_DZ_EN<br>PWM01 Dead Zone Enable<br>0: Dead Zone disable<br>1: Dead Zone enable. |

#### 10.11.6.9. 0x0064 PWM23 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Offset:0x0064 |            |             | Register Name: PDZCR23                          |
|---------------|------------|-------------|-------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                     |
| 31:16         | /          | /           | /                                               |
| 15:8          | R/W        | 0x0         | PWM23_DZ_INTV<br>PWM23 Dead Zone Interval Value |
| 7:1           | /          | /           | /                                               |
| 0             | R/W        | 0x0         | PWM23_DZ_EN<br>PWM23 Dead Zone Enable           |

|  |  |  |                                             |
|--|--|--|---------------------------------------------|
|  |  |  | 0: Dead Zone disable<br>1: Dead Zone enable |
|--|--|--|---------------------------------------------|

#### 10.11.6.10. 0x0080 PWM Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0080 |            |             | Register Name: PER                         |
|---------------|------------|-------------|--------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                |
| 31:4          | /          | /           | /                                          |
| 3             | R/W        | 0x0         | PWM3_EN<br>0: PWM disable<br>1: PWM enable |
| 2             | R/W        | 0x0         | PWM2_EN<br>0: PWM disable<br>1: PWM enable |
| 1             | R/W        | 0x0         | PWM1_EN<br>0: PWM disable<br>1: PWM enable |
| 0             | R/W        | 0x0         | PWM0_EN<br>0: PWM disable<br>1: PWM enable |

#### 10.11.6.11. 0x0090 PWM Group0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: PGR0                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG0_START<br>PWM channels selected in PWMG0_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG0_EN<br>PWM Group0 Enable.                                                                  |
| 15:0           | R/W        | 0x0         | PWMG0_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group0.                   |

#### 10.11.6.12. 0x0094 PWM Group1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: PGR1                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:18          | /          | /           | /                                                                                |
| 17             | R/WAC      | 0x0         | PWMG1_START<br>PWM channels selected in PWMG1_CS start to output PWM waveform at |

|      |     |     |                                                                               |
|------|-----|-----|-------------------------------------------------------------------------------|
|      |     |     | the same time.                                                                |
| 16   | R/W | 0x0 | PWMG1_EN<br>PWM Group1 Enable.                                                |
| 15:0 | R/W | 0x0 | PWMG1_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group1. |

#### 10.11.6.13. 0x0098 PWM Group2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: PGR2                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG2_START<br>PWM channels selected in PWMG2_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG2_EN<br>PWM Group2 Enable.                                                                  |
| 15:0           | R/W        | 0x0         | PWMG2_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group2.                   |

#### 10.11.6.14. 0x009C PWM Group3 Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: PGR3                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG3_START<br>PWM channels selected in PWMG3_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG3_EN<br>PWM Group3 Enable.                                                                  |
| 15:0           | R/W        | 0x0         | PWMG3_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group3.                   |

#### 10.11.6.15. 0x00C0 Capture Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:4           | /          | /           | /                                                                                                                                                                                      |
| 3              | R/W        | 0x0         | CAP3_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel3 is permitted to capture external falling edge or rising edge.<br>0: Capture disable |

|   |     |     |                                                                                                                                                                                                             |
|---|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: Capture enable                                                                                                                                                                                           |
| 2 | R/W | 0x0 | CAP2_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel2 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 1 | R/W | 0x0 | CAP1_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel1 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 0 | R/W | 0x0 | CAP0_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel0 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |

#### 10.11.6.16. 0x0100 + N\*0x20 PWM Control Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x0+N*0x20(N=0~3) |            |             | Register Name: PCR                                                                                                                                                                                                                                                                  |
|---------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31:16                           | R/W        | 0x0         | PWM_PUL_NUM<br>In pulse mode, PWM output pulse for PWM_CYCLE_NUM+1 times and then stop.                                                                                                                                                                                             |
| 15:12                           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 11                              | R          | 0x0         | PWM_PERIOD_RDY<br>PWM Period Register Ready<br>0: PWM period register is ready to write<br>1: PWM period register is busy                                                                                                                                                           |
| 10                              | R/W1S      | 0x0         | PWM_PUL_START<br>PWM Pulse Output Start<br>0: No effect<br>1: Output pulse for PWM_CYCLE_NUM+1.<br>After finishing configuration for outputting pulse, set this bit once and then PWM would output waveform. After the waveform is finished, the bit will be cleared automatically. |
| 9                               | R/W        | 0x0         | PWM_MODE<br>PWM Output Mode Select<br>0: Cycle mode<br>1: Pulse mode                                                                                                                                                                                                                |
| 8                               | R/W        | 0x0         | PWM_ACT_STA<br>PWM Active State<br>0: Low Level<br>1: High Level                                                                                                                                                                                                                    |

|     |     |     |                                                                                                                                                                                                                                 |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | R/W | 0x0 | PWM_PRESCAL_K<br>PWM pre-scale K, actual pre-scale is (K+1).<br>K = 0, actual pre-scale: 1<br>K = 1, actual pre-scale: 2<br>K = 2, actual pre-scale: 3<br>K = 3, actual pre-scale: 4<br>.....<br>K = 255, actual pre-scale: 256 |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 10.11.6.17. 0x0104 + N\*0x20 PWM Period Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x04+N*0x20(N=0~3) |            |             | Register Name: PPR                                                                                                                                                                                                      |
|----------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 31:16                            | R/W        | 0x0         | PWM_ENTIRE_CYCLE<br>Number of the entire cycles in the PWM clock.<br>0: 1 cycle<br>1: 2 cycles<br>...<br>N: N+1 cycles<br>If the register needs to be modified dynamically, the PCLK should be faster than the PWM CLK. |
| 15:0                             | R/W        | 0x0         | PWM_ACT_CYCLE<br>Number of the active cycles in the PWM clock.<br>0: 0 cycle<br>1: 1 cycle<br>...<br>N: N cycles                                                                                                        |

#### 10.11.6.18. 0x0108 + N\*0x20 PWM Counter Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x08+N*0x20(N=0~3) |            |             | Register Name: PCNTR                                                                                                                  |
|----------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:16                            | /          | /           | /                                                                                                                                     |
| 15:0                             | R          | 0x0         | PWM_COUNTER_STATUS<br>On PWM output or capture input, reading this register could get the current value of the PWM 16-bit up-counter. |

#### 10.11.6.19. 0x010C + N\*0x20 PWM Pulse Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0100+0x0C+N*0x20(N=0~3) |            |             | Register Name: PPCNTR |
|-----------------------------------|------------|-------------|-----------------------|
| Bit                               | Read/Write | Default/Hex | Description           |
| 31:16                             | /          | /           | /                     |

|      |   |     |                                                                                                                       |
|------|---|-----|-----------------------------------------------------------------------------------------------------------------------|
| 15:0 | R | 0x0 | PWM_PUL_COUNTER_STATUS<br>On PWM output , reading this register could get the current value of the PWM pulse counter. |
|------|---|-----|-----------------------------------------------------------------------------------------------------------------------|

#### 10.11.6.20. 0x0110 + N\*0x20 PWM Capture Control Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x10+N*0x20(N=0~3) |            |             | Register Name: CCR                                                                                                                                                                      |
|----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:5                             | /          | /           | /                                                                                                                                                                                       |
| 4                                | R/W1C      | 0x0         | CRLF<br>When capture channel captures rising edge, the current value of the 16-bit up-counter is latched to CRLR and then this bit is set 1 by hardware.<br>Write 1 to clear this bit.  |
| 3                                | R/W1C      | 0x0         | CFLF<br>When capture channel captures falling edge, the current value of the 16-bit up-counter is latched to CFLR and then this bit is set 1 by hardware.<br>Write 1 to clear this bit. |
| 2                                | R/W        | 0x0         | CRTE<br>Rising edge capture trigger enable                                                                                                                                              |
| 1                                | R/W        | 0x0         | CFTE<br>Falling edge capture trigger enable                                                                                                                                             |
| 0                                | R/W        | 0x0         | CAPINV<br>Inversing the signal input from capture channel before 16-bit counter of capture channel.<br>0: not inverse<br>1: inverse                                                     |

#### 10.11.6.21. 0x0114 + N\*0x20 PWM Capture Rise Lock Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x14+N*0x20(N=0~3) |            |             | Register Name: CRLR                                                                                                |
|----------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                        |
| 31:16                            | /          | /           | /                                                                                                                  |
| 15:0                             | R          | 0x0         | When capture channel captures rising edge, the current value of the 16-bit up-counter is latched to this register. |

#### 10.11.6.22. 0x0118 + N\*0x20 PWM Capture Fall Lock Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x18+N*0x20(N=0~3) |            |             | Register Name: CFLR                                                        |
|----------------------------------|------------|-------------|----------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                |
| 31:16                            | /          | /           | /                                                                          |
| 15:0                             | R          | 0x0         | When the capturing channel captures the falling edge, the current value of |

|  |  |  |                                                   |
|--|--|--|---------------------------------------------------|
|  |  |  | the 16-bit up-counter is latched to the register. |
|--|--|--|---------------------------------------------------|

Confidential

## 10.12. LEDC

### 10.12.1. Overview

The LEDC is used to control external LED lamp.

The LEDC has the following features:

- Configurable LED output high/low level width
- Configurable LED reset time
- LEDC data supports DMA configuration mode and CPU configuration mode
- Maximum 1024 LED serial connect
- LED data transfer rate up to 800 kbit/s
- Configurable RGB display mode
- Non-data output default level is configurable

### 10.12.2. Block Diagram

Figure 10-69 shows a block diagram of the LEDC.



Figure 10- 69. LEDC Block Diagram

config: register configuration

control: LEDC timing control and status control

FIFO: 24\*32 data FIFO

Data\_trans: input data converts to 0 character and 1 character

### 10.12.3. Operations and Functional Descriptions

#### 10.12.3.1. External Signals

Table 10-32 describes the external signals of the LEDC.

**Table 10- 32. LEDC External Signals**

| Signal | Description                           | Type |
|--------|---------------------------------------|------|
| LEDC   | Intelligent control LED signal output | O    |

#### 10.12.3.2. Clock Sources

**Table 10- 33. LEDC Clock Sources**

| Clock Sources | Description                                                           |
|---------------|-----------------------------------------------------------------------|
| LEDC_CLK      | 24 MHz(fixed)                                                         |
| APB_CLK       | 250 MHz(changed), support range:24 MHz~250 MHz, typical value:200 MHz |

#### 10.12.3.3. LEDC Timing


**Figure 10- 70. LEDC Package Output Timing Diagram**

**Figure 10- 71. LEDC 1-frame Output Timing Diagram**

#### 10.12.3.4. LEDC Input Data Structure

The RGB mode of LEDC data is configurable. By default, the data is sent in GRB order, and the higher bit is transmitted first.



**Figure 10- 72. LEDC Input Data Structure****10.12.3.5. LEDC Typical Circuit**

C1: filter capacitor of LED , usually is 100nF

**Figure 10- 73. LEDC Typical Circuit****10.12.3.6. LEDC Data Input Code****Figure 10- 74. LEDC Data Input Code****10.12.3.7. LEDC Data Transfer Time**

The time parameters of typical LED datasheet are as follows.

|       |                            |               |
|-------|----------------------------|---------------|
| TOH   | 0 code, high-level time    | 220 ns-380 ns |
| TOL   | 0 code, low-level time     | 580 ns-1.6 us |
| T1H   | 1 code, high-level time    | 580 ns-1.6 us |
| T1L   | 1 code, low-level time     | 220 ns-420 ns |
| RESET | Frame unit, low-level time | > 280 us      |

### 10.12.3.8. LEDC Data Transfer Mode



Figure 10- 75. LEDC Data Transfer Mode

### 10.12.3.9. LEDC Parameter

(1) PAD rate > 800 kbit/s

(2) LED number supported:

$T_0\text{-code}$ : 800 ns~1980 ns,  $T_1\text{-code}$ : 800 ns~2020 ns

When LED refresh rate is 30 frame/s, LED number supported is  $(1s/30-280 \mu s)/((800 \text{ ns} \sim 2020 \text{ ns}) * 24) = 1024 \sim 681$ .

When LED refresh rate is 60 frame/s, LED number supported is  $(1s/60-280 \mu s)/((800 \text{ ns} \sim 2020 \text{ ns}) * 24) = 853 \sim 338$ .

### 10.12.3.10. LEDC Data Transfer

LEDC supports DMA data transfer mode or CPU data transfer mode. DMA data transfer mode is set by LEDC\_DMA\_EN.

- **Data transfer in DMA mode**

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, LEDC sends DMA\_REQ to require DMA to transfer data from DRAM to LEDC. The maximum data transfer size in DMA mode is 16 word.(The internal FIFO level is 32.)

- **Data transfer in CPU mode**

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, LEDC sends LEDC\_CPUREQ\_INT to require CPU to transfer data to LEDC. The transfer data size in CPU mode is controlled by software. The internal FIFO destination address is 0x06700014. The data width is 32-bit.(The lower 24-bit is valid.)

### 10.12.3.11. LEDC Interrupt

| Module Name       | Description                                                                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO_OVERFLOW_INT | FIFO overflow interrupt.<br>The data written by external is more than the maximum storage space of LED FIFO, LEDC will be in data loss state. At this time, software needs to deal with |

|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | <p>the abnormal situation. The processing mode is as follows.</p> <p>Software can query LED_FIFO_DATA_REG to determine which data has been stored in internal FIFO of LEDC. LEDC performs soft_reset operation to refresh all data.</p>                                                                                                                                                                                                                                                                                                                                                                                                    |
| WAITDATA_TIMEOUT_INT  | <p>Wait data timeout interrupt</p> <p>When internal FIFO of LEDC cannot get data because of some abnormal situation, after led_wait_data_time, timeout interrupt is set, LEDC is in WAIT_DATA state, LEDC outputs a level state configured by LED_POLARITY; in the course of wait_data, if new data arrives, LEDC will continue to send data, at this time software needs to notice whether the waiting time of LEDC exceeds the operation time of reset. If the waiting time of LEDC exceeds the operation time of reset(this is equivalent to reset operation sent by LEDC), LED may enter in refresh state, data has not been sent.</p> |
| FIFO_CPUREQ_INT       | <p>FIFO request CPU data interrupt</p> <p>When FIFO data is less than threshold, the interrupt will be reported to CPU.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LEDC_TRANS_FINISH_INT | <p>Data transfer complete interrupt</p> <p>The value indicates that the data configured as total_data_length has been transferred complete.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

LEDC interrupt usage scenario:

#### (1) CPU mode

Software can enable GLOBAL\_INT\_EN,FIFO\_CPUREQ\_INT\_EN,WAITDATA\_TIMEOUT\_INT\_EN,FIFO\_OVERFLOW\_INT\_EN,LEDCE\_TRANS\_FINISH\_INT\_EN, and cooperate with LEDC\_FIFO\_TRIG\_LEVEL to use. When FIFO\_CPUREQ\_INT is set to 1, the software can configure data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

#### (2) DMA mode

Software can enable GLOBAL\_INT\_EN,WAITDATA\_TIMEOUT\_INT\_EN,FIFO\_OVERFLOW\_INT\_EN,LEDCE\_TRANS\_FINISH\_INT\_EN, and cooperate with LEDC\_FIFO\_TRIG\_LEVEL to use. When DMA receives LEDC DMA\_REQ, DMA can transfer data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

### 10.12.4. Programming Guidelines

#### 10.12.4.1. LEDC Normal Configuration Process

**Step1** Configure LEDC\_CLK and bus pclk.

**Step2** Configure the written LEDC data.

**Step3** Configure LED\_T1/0\_TIMING\_CTRL\_REG, LEDC\_DATA\_FINISH\_CNT\_REG, LED\_RESET\_TIMING\_CTRL\_REG, LEDC\_WAIT\_TIME\_CTRL\_REG, LEDC\_DMA\_CTRL\_REG, LEDC\_INTERRUPT\_CTRL\_REG. Configure 0-code, 1-code, reset time, LEDC waiting time, and the number of external connected LEDC and the threshold of DMA transfer data.

**Step4** Configure LEDC\_CTRL\_REG to enable LEDC\_EN, LEDC will start to output data.

**Step5** When LEDC interrupt is pulled up, it indicates the configured data has transferred complete, at this time LED\_EN will be set to 0, and the read&write point of LEDC FIFO is cleared to 0.

Step6 Repeat step1,2,3,4 to re-execute a new round of configuration, enable LEDC\_EN, LEDC will start new data transfer.



Figure 10- 76. LEDC Normal Configuration Process

#### 10.12.4.2. LEDC Abnormal Scene Processing Flow

##### (1) WAITDATA\_TIMEOUT Abnormal Status

**Step1** WAITDATA\_TIMEOUT indicates internal FIFO data request of LEDC cannot obtain response, at this time if the default output level is low level, then external LED may think there was a reset operation and cause LED data to be flushed incorrectly.

**Step2** LEDC needs be performed soft\_reset operation, that is LEDC\_SOFT\_RESET=1; after soft\_reset, LEDC\_EN will be pulled-down automatically, all internal status register and control state machine will return to idle state, LEDC FIFO read & write point is cleared to 0, LEDC interrupt is cleared.

**Step3** Setting reset\_led\_en to 1 indicates LEDC can send proactive a reset operation to ensure external LED lamp in right state.

**Step4** Software reads the state of reset\_led\_en, when is 1, it indicates LEDC does not perform the transmission of LED reset operation; when is 0, LEDC completes the transmission of LED reset operation.

**Step5** When LEDC reset operation finishes, the LEDC data and register configuration need be reoperated to start retransmission data operation.



Figure 10- 77. LEDC Timeout Abnormal Processing Flow

## (2) FIFO Overflow Abnormal Status

**Step1** FIFO\_OVERFLOW\_INT indicates software configured data exceeds LEDC FIFO space, at this time redundant data will be lost.

**Step2** Software needs read data in LEDC\_FIFO\_DATA\_REG register to confirm the lost data.

**Step3** Software re-configures the lost data to LEDC.

**Step4** If software uses soft\_reset operation, the operation is the same with timeout abnormal processing flow.



Figure 10- 78. FIFO Overflow Abnormal Processing Flow

### 10.12.5. Register List

| Module Name | Base Address |
|-------------|--------------|
| LEDC        | 0x05018000   |

| Register Name             | Offset     | Description                       |
|---------------------------|------------|-----------------------------------|
| LED_CTR_CTRL_REG          | 0x0000     | LEDC Control Register             |
| LED_T1&0_TIMING_CTRL_REG  | 0x0004     | LED T0 Timing Control Register    |
| LED_CDATA_FINISH_CNT_REG  | 0x0008     | LEDC Data Finish Counter Register |
| LED_RESET_TIMING_CTRL_REG | 0x000C     | LED Reset Timing Control Register |
| LED_WAIT_TIME0_CTRL_REG   | 0x0010     | Wait Time0 Control Register       |
| LED_CDATA_REG             | 0x0014     | LEDC Data Register                |
| LED_CDMA_CTRL_REG         | 0x0018     | DMA Control Register              |
| LED_CINT_CTRL_REG         | 0x001C     | Interrupt Control Register        |
| LED_CINT_STS_REG          | 0x0020     | Interrupt Status Register         |
| LED_WAIT_TIME1_CTRL_REG   | 0x0028     | Wait Time1 Control Register       |
| LED_C FIFO DATA REG       | 0x0030+4*N | LEDC FIFO Data Register           |

### 10.12.6. Register Description

#### 10.12.6.1. 0x0000 LEDC Control Register (Default Value: 0x0000\_003C)

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                |
| 28:16          | R/W        | 0x0         | <p>TOTAL_DATA_LENGTH<br/>Total length of transfer data(range: 0 to 8K,unit:32-bit,only low 24-bit is valid)<br/>The field is recommended to be set to an integer multiple of (LED_NUM+1).<br/>If TOTAL_DATA_LENGTH is greater than (LED_NUM+1), but non integer multiple, the last frame of data will transfer data less than (LED_NUM+1).</p>                                                   |
| 15:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                |
| 10             | R/W        | 0x0         | <p>RESET_LED_EN<br/>Write operation:<br/>Software writes 1, CPU triggers LEDC to transfer a reset to LED.<br/><b>Note:</b></p> <ul style="list-style-type: none"> <li>Only when LEDC is in IDLE status, reset can be performed. After reset finished, the control state machine returns to the IDLE status.</li> <li>To return LEDC to the IDLE status, it also needs to be used with</li> </ul> |

|                     |               |                  | <p><b>SOFT_RESET.</b></p> <ul style="list-style-type: none"> <li>When software sets the bit, software can read the bit to check if reset is complete.</li> </ul> <p>Read operation:</p> <p>0: LEDC completes the transmission of LED reset operation<br/>1: LEDC does not complete the transmission of LED reset operation</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|---------------------|---------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 9                   | /             | /                | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 8:6                 | R/W           | 0x0              | <p>LED_RGB_MODE</p> <p>000: GRB(bypass)</p> <p>001: GBR</p> <p>010: RGB</p> <p>011: BGR</p> <p>100: RBG</p> <p>101: BRG</p> <p>By default, software configures data to LEDC according to GRB(MSB) mode, LEDC internal combines data to output to the external LED.</p> <p>Other modes configures as follows.</p> <table border="1"> <thead> <tr> <th>Software Input Mode</th><th>Configuration</th><th>LEDC Output Mode</th></tr> </thead> <tbody> <tr> <td rowspan="6">GRB</td><td>000</td><td>GRB</td></tr> <tr> <td>001</td><td>GBR</td></tr> <tr> <td>010</td><td>RGB</td></tr> <tr> <td>011</td><td>RBG</td></tr> <tr> <td>100</td><td>BGR</td></tr> <tr> <td>101</td><td>BRG</td></tr> <tr> <td rowspan="6">GBR</td><td>000</td><td>GBR</td></tr> <tr> <td>001</td><td>GRB</td></tr> <tr> <td>010</td><td>BGR</td></tr> <tr> <td>011</td><td>BRG</td></tr> <tr> <td>100</td><td>RGB</td></tr> <tr> <td>101</td><td>RBG</td></tr> <tr> <td rowspan="6">RGB</td><td>000</td><td>RGB</td></tr> <tr> <td>001</td><td>RBG</td></tr> <tr> <td>010</td><td>GRB</td></tr> <tr> <td>011</td><td>GBR</td></tr> <tr> <td>100</td><td>BRG</td></tr> <tr> <td>101</td><td>BGR</td></tr> <tr> <td rowspan="5">RBG</td><td>000</td><td>RBG</td></tr> <tr> <td>001</td><td>RGB</td></tr> <tr> <td>010</td><td>BRG</td></tr> <tr> <td>011</td><td>BGR</td></tr> <tr> <td>100</td><td>GRB</td></tr> </tbody> </table> | Software Input Mode | Configuration | LEDC Output Mode | GRB | 000 | GRB | 001 | GBR | 010 | RGB | 011 | RBG | 100 | BGR | 101 | BRG | GBR | 000 | GBR | 001 | GRB | 010 | BGR | 011 | BRG | 100 | RGB | 101 | RBG | RGB | 000 | RGB | 001 | RBG | 010 | GRB | 011 | GBR | 100 | BRG | 101 | BGR | RBG | 000 | RBG | 001 | RGB | 010 | BRG | 011 | BGR | 100 | GRB |
| Software Input Mode | Configuration | LEDC Output Mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GRB                 | 000           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GBR                 | 000           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| RGB                 | 000           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| RBG                 | 000           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |     |  |
|---|-------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|--|
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 101 | GBR |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 000 | BGR |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 001 | BRG |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 010 | GBR |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 011 | GRB |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 100 | RBG |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 101 | RGB |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 000 | BRG |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 001 | BGR |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 010 | RBG |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 011 | RGB |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 100 | GBR |  |
|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 101 | GRB |  |
| 5 | R/W   | 0x1 | LED_MSB_TOP<br>Adjust sequence of the combined GRB data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |     |  |
| 4 | R/W   | 0x1 | LED_MSB_G<br>MSB control for Green data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |     |  |
| 3 | R/W   | 0x1 | LED_MSB_R<br>MSB control for Red data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |     |  |
| 2 | R/W   | 0x1 | LED_MSB_B<br>MSB control for Blue data<br>0:LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |     |  |
| 1 | R/W1C | 0x0 | LEDC_SOFT_RESET<br>LEDC soft reset<br>Write 1 to clear it automatically.<br>The range of LEDC soft reset: all internal status registers, the control state machine returns to in idle status, LEDC FIFO read & write point is cleared to 0, LEDC interrupt is cleared, the affected registers are follow.<br>1.LEDC_CTRL_REG(LEDC_EN is cleared to 0);<br>2. PLL_T0&1_TIMING_CTRL_REG remains unchanged;<br>3. LEDC_DATA_FINISH_CNT_REG(LEDC_DATA_FINISH_CNT is cleared to 0)<br>4.LED_RESET_TIMING_CTRL_REG remains unchanged;<br>5. LEDC_WAIT_TIME_CTRL_REG remains unchanged;<br>6. LEDC_DMA_CTRL_REG remains unchanged;<br>7. LEDC_INTERRUPT_CTRL_REG remains unchanged;<br>8.LEDC_INT_STS _REG is cleared to 0;<br>9. LEDC_CLK_GATING_REG remains unchanged; |     |     |  |

|   |     |     |                                                                                                                                                                                                                                 |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 10.LEDC_FIFO_DATA_REG remains unchanged;                                                                                                                                                                                        |
| 0 | R/W | 0x0 | <p>LEDC_EN<br/>LEDC Enable<br/>0: Disable<br/>1: Enable<br/>That the bit is enabled indicates LEDC can be started when LEDC data finished transmission or LEDC_EN is cleared to 0 by hardware in LEDC_SOFT_RESET situation.</p> |

#### 10.12.6.2. 0x0004 LED\_T01\_Timing Control Register (Default Value: 0x0286\_01D3)

| Offset: 0x0004 |            |             | Register Name: LED_T01_TIMING_CTRL_REG                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:27          | /          | /           | /                                                                                                                                                                                |
| 26:21          | R/W        | 0x14        | <p>T1H_TIME<br/>LED T1H time<br/>Unit: cycle(24MHz), T1H_TIME =42ns*(N+1)<br/>The default value is 800ns, the range is 80ns~2560ns.<br/>N: 1~3F<br/>When is 0, T1H_TIME = 3F</p> |
| 20:16          | R/W        | 0x6         | <p>T1L_TIME<br/>LED T1L time<br/>Unit: cycle(24MHz), T1L_TIME =42ns*(N+1)<br/>The default value is 280ns, the range is 80ns~1280ns.<br/>N: 1~1F<br/>When is 0, T1L_TIME = 1F</p> |
| 15:11          | /          | /           | /                                                                                                                                                                                |
| 10:6           | R/W        | 0x7         | <p>TOH_TIME<br/>LED TOh time<br/>Unit: cycle(24MHz), TOH_TIME =42ns*(N+1)<br/>The default value is 280ns, the range is 80ns~1280ns.<br/>N: 1~1F<br/>When is 0, TOH_TIME = 1F</p> |
| 5:0            | R/W        | 0x13        | <p>TOL_TIME<br/>LED T0l time<br/>Unit: cycle(24MHz), TOL_TIME =42ns*(N+1)<br/>The default value is 800ns, the range is 80ns~2560ns.<br/>N: 1~3F<br/>When is 0, TOL_TIME = 3F</p> |

#### 10.12.6.3. 0x0008 LEDC Data Finish Counter Register (Default Value: 0x1D4C\_0000)

| Offset: 0x0008 | Register Name: LEDC_DATA_FINISH_CNT_REG |
|----------------|-----------------------------------------|
|----------------|-----------------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29:16 | R/W        | 0x1d4c      | <p>LED_WAIT_DATA_TIME<br/>                     The value is the time that internal FIFO in LEDC is waiting data, when the setting time is exceeded , LEDC will send waitdata_timeout_int interrupt.<br/>                     (This is a abnormal situation, software needs to reset LEDC.)<br/>                     The value is 300 us by default.</p> <p>The adjust range is from 80 ns to 655 us, led_wait_data_time=42 ns*(N+1)<br/>                     N: 1~1FFF</p> <p>When the field is 0, LEDC_WAIT_DATA_TIME=1FFF</p> |
| 15:13 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12:0  | R          | 0x0         | <p>LED_DATA_FINISH_CNT<br/>                     The value is the total LED data that have been sent .(Range: 0~8k)</p>                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 10.12.6.4. 0x000C LED Reset Timing Control Register(Default Value: 0x1D4C\_0000)

| Offset: 0x000C |            |             | Register Name: LED_RESET_TIMING_CTRL_REG                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                  |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                            |
| 28:16          | R/W        | 0x1d4c      | <p>TR_TIME<br/>                     Reset time control of LED lamp<br/>                     Unit: cycle(24 MHz), tr_time=42ns*(N+1)<br/>                     The default value is 300 us.<br/>                     The adjust range is from 80 ns to 327 us.<br/>                     N: 1~1FFF</p> <p>When the field is 0, TR_TIME=1FFF</p> |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                            |
| 9:0            | R/W        | 0x0         | <p>LED_NUM<br/>                     The value is the number of external LED lamp. Maximum up to 1024.<br/>                     The default value 0 indicates that 1 LED lamp is external connected. The range is from 0 to 1023.</p>                                                                                                         |

#### 10.12.6.5. 0x0010 LEDC Wait Time 0 Control Register (Default Value: 0x0000\_00FF)

| Offset: 0x0010 |            |             | Register Name: LEDC_WAIT_TIME0_CTRL_REG                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                         |
| 31:9           | /          | /           | /                                                                                                                                                                                                                   |
| 8              | R/W        | 0x0         | <p>WAIT_TIM0_EN<br/>                     WAIT_TIME0 enable<br/>                     When it is 1, the controller automatically insert waiting time before LED package data.<br/>                     0: Disable</p> |

|     |     |      |                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |      | 1: Enable                                                                                                                                                                                                                                                                                                                                                      |
| 7:0 | R/W | 0xFF | <p><b>TOTAL_WAIT_TIME0</b><br/>                     Waiting time between 2 LED datas, LEDC output is low level.<br/>                     The adjust range is from 80 ns to 10 us. wait_time0=42 ns*(N+1)<br/>                     Unit: cycle(24 MHz)<br/>                     N: 1~FF<br/>                     When the field is 0, TOTAL_WAIT_TIME1E=FF.</p> |

#### 10.12.6.6. 0x0014 LEDC Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: LEDC_DATA_REG                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:0           | W          | 0x0         | <p><b>LEDC DATA</b><br/>                     LED display data(the lower 24-bit is valid)</p> |

#### 10.12.6.7. 0x0018 LEDC DMA Control Register (Default: 0x0000\_002F)

| Offset: 0x0018 |            |             | Register Name: LEDC_DMA_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5              | R/W        | 0x1         | <p><b>LEDC_DMA_EN</b><br/>                     LEDC DMA request enable<br/>                     0: Disable request of DMA transfer data<br/>                     1: Enable request of DMA transfer data</p>                                                                                                                                                                                                                                                                                                            |
| 4:0            | R/W        | 0x0F        | <p><b>LEDC_FIFO_TRIG_LEVEL</b><br/>                     The remaining space of internal FIFO in LEDC<br/>                     The internal FIFO in LEDC is 24*32.<br/>                     When the remaining space of internal FIFO in LEDC is more than or equal to LEDFIFO_TRIG_LEVEL, DMA or CPU request will generate. The default value is 15.<br/>                     The adjust value is from 1 to 31. The recommended configuration is 7 or 15. When the configuration value is 0, LEDFIFO_TRIG_LEVEL=F.</p> |

#### 10.12.6.8. 0x001C LEDC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: LEDC_INTERRUPT_CTRL_REG                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31:6           | /          | /           | /                                                                                                                |
| 5              | R/W        | 0x0         | <p><b>GLOBAL_INT_EN</b><br/>                     Global interrupt enable<br/>                     0: Disable</p> |

|   |     |     |                                                                                                                                                                                                          |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 1: Enable                                                                                                                                                                                                |
| 4 | R/W | 0x0 | FIFO_OVERFLOW_INT_EN<br>FIFO overflow interrupt enable<br>When the data written by software is more than internal FIFO level of LEDC, LEDC is in data loss state.<br>0: Disable<br>1: Enable             |
| 3 | R/W | 0x0 | WAITDATA_TIMEOUT_INT_EN<br>The internal FIFO in LEDC cannot get data because of some abnormal situation, after the time of led_wait_data_time, the interrupt will be enabled.<br>0: Disable<br>1: Enable |
| 2 | /   | /   | /                                                                                                                                                                                                        |
| 1 | R/W | 0x0 | FIFO_CPUREQ_INT_EN<br>FIFO request CPU data interrupt enable<br>0: Disable<br>1: Enable                                                                                                                  |
| 0 | R/W | 0x0 | LED_TRANS_FINISH_INT_EN<br>Data transmission complete interrupt enable<br>0: Disable<br>1: Enable                                                                                                        |

#### 10.12.6.9. 0x0020 LEDC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: LEDC_INT_STS_REG                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 17             | R          | 0x1         | FIFO_EMPTY<br>FIFO empty status flag                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16             | R          | 0x0         | FIFO_FULL<br>FIFO full status flag                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:10          | R          | 0x0         | FIFO_WLW<br>FIFO internal valid data depth<br>It indicates the space FIFO has been occupied.                                                                                                                                                                                                                                                                                                                                             |
| 9:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4              | R/W1C      | 0x0         | FIFO_OVERFLOW_INT<br>FIFO overflow interrupt<br>The data written by external is more than the maximum storage space of LED FIFO, LEDC will be in data loss state. At this time, software needs to deal with the abnormal situation. The processing mode is as follows.<br>Software can query LED_FIFO_DATA_REG to determine which data has been stored in internal FIFO of LEDC. LEDC performs soft_reset operation to refresh all data. |

|   |       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | 0: FIFO not overflow<br>1: FIFO overflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3 | R/W1C | 0x0 | <p>WAITDATA_TIMEOUT_INT</p> <p>When internal FIFO of LEDC cannot get data because of some abnormal situation, after led_wait_data_time, timeout interrupt is set, LEDC is in WAIT_DATA state, LEDC outputs a level state configured by LED_POLARITY; in the course of wait_data, if new data arrives, LEDC will continue to send data, at this time software needs to notice whether the waiting time of LEDC exceeds the operation time of reset. If the waiting time of LEDC exceeds the operation time of reset(this is equivalent to reset operation sent by LEDC), LED may enter in refresh state, data has not been sent.</p> <p>0: LEDC not timeout<br/>1: LEDC timeout</p> |
| 2 | /     | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1 | R/W1C | 0x0 | <p>FIFO_CPUREQ_INT</p> <p>FIFO request CPU data interrupt</p> <p>When FIFO data is less than threshold, the interrupt will be reported to CPU.</p> <p>0: FIFO does not request that CPU transfers data<br/>1: FIFO requests that CPU transfers data</p>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0 | R/W1C | 0x0 | <p>LED_TRANS_FINISH_INT</p> <p>Data transfer complete interrupt</p> <p>The value indicates that the data configured as total_data_length has been transferred complete.</p> <p>0: Data not transfer complete<br/>1: Data transfer complete</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 10.12.6.10. 0x0028 LEDC Wait Time 1 Control Register (Default Value: 0x1FF\_FFFF)

| Offset: 0x0028 |            |             | Register Name: LEDC_WAIT_TIME1_CTRL_REG                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
| 31             | R/W        | 0x0         | <p>WAIT_TIM1_EN</p> <p>0: Disable<br/>1: Enable</p> <p>WAIT_TIME1 enable</p> <p>When the bit is 1, the controller automatically insert waiting time before LED frame data.</p>                                       |
| 30:0           | R/W        | 0x1FF_FFFF  | <p>TOTAL_WAIT_TIME1</p> <p>Waiting time between 2 frame datas, LEDC output is low level.</p> <p>The adjust range is from 80 ns to 85 s. wait_time1=42 ns*(N+1)</p> <p>Unit: cycle(24 MHz)</p> <p>N: 80~7FFF_FFFF</p> |

**10.12.6.11. 0x0030+N\*0x4 LEDC FIFO Data Register X (Default Value: 0x0000\_0000)**

| Offset: 0x0030+N*0x4(N=0~31) |            | Register Name: LEDC_FIFO_DATA_X |                                                                              |
|------------------------------|------------|---------------------------------|------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex                     | Description                                                                  |
| 31:0                         | R          | 0x0                             | LEDC_FIFO_DATA_X<br>Internal FIFO data of LEDC<br>The lower 24-bit is valid. |

## 10.13. EMAC

### 10.13.1. Overview

The Ethernet Medium Access Controller (EMAC) enables a host to transmit and receive data over Ethernet in compliance with the IEEE 802.3-2002 standard. It supports 10/100/1000 Mbit/s external PHY with RMII/RGMII interface in both full and half duplex mode. The internal DMA is designed for packet-oriented data transfers based on a linked list of descriptors. 2 KB TXFIFO and 8 KB RXFIFO are provided to keep continuous transmission and reception. Flow Control, CRC Pad & Stripping, and address filtering are also supported in this module.

The EMAC has the following features:

- 10/100/1000 Mbit/s Ethernet port with RGMII and RMII interfaces
- Supports RMII/RGMII PHY interface
- Supports MDIO
- Supports both full-duplex and half-duplex operation
- 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

### 10.13.2. Block Diagram

The block diagram of EMAC is shown below.



Figure 10- 79. EMAC Block Diagram

### 10.13.3. Operations and Functional Descriptions

#### 10.13.3.1. External Signals

Table 10-34 describes the pin mapping of EMAC.

Table 10- 34. EMAC Pin Mapping

| Pin Name                  | RGMII    | RMII     |
|---------------------------|----------|----------|
| RGMII0_RXD3/RMII0_NULL    | RXD3     | /        |
| RGMII0_RXD2/RMII0_NULL    | RXD2     | /        |
| RGMII0_RXD1/RMII0_RXD1    | RXD1     | RXD1     |
| RGMII0_RXD0/RMII0_RXD0    | RXD0     | RXD0     |
| RGMII0_RXCK/RMII0_NULL    | RXCK     | /        |
| RGMII0_RXCTL/RMII0_CRS_DV | RXCTL    | CRS_DV   |
| RGMII0_CLKIN /RMII0_RXER  | CLKIN    | RXER     |
| RGMII0_TXD3/RMII0_NULL    | TXD3     | /        |
| RGMII0_TXD2/RMII0_NULL    | TXD2     | /        |
| RGMII0_TXD1/RMII0_TXD1    | TXD1     | TXD1     |
| RGMII0_TXD0/RMII0_TXD0    | TXD0     | TXD0     |
| RGMII0_TXCK/RMII0_TXCK    | TXCK     | TXCK     |
| RGMII0_TXCTL/RMII0_TXEN   | TXCTL    | TXEN     |
| MDC0                      | MDC      | MDC      |
| MDIO0                     | MDIO     | MDIO     |
| EPHY0_25                  | EPHY0_25 | EPHY0_25 |

Table 10-35 describes the pin list of RGMII.

**Table 10- 35. EMAC RGMII Pin List**

| Pin Name        | Description                           | Type |
|-----------------|---------------------------------------|------|
| RGMII0_TXD[3:0] | EMAC RGMII transmit data              | O    |
| RGMII0_TXCTL    | EMAC RGMII transmit control           | O    |
| RGMII0_RXCK     | EMAC RGMII transmit clock             | O    |
| RGMII0_RXD[3:0] | EMAC RGMII receive data               | I    |
| RGMII0_RXCTL    | EMAC RGMII receive control            | I    |
| RGMII0_RXCK     | EMAC RGMII receive clock              | I    |
| RGMII0_CKIN     | EMAC RGMII 125M reference clock input | I    |
| MDC0            | EMAC management data clock            | O    |
| MDIO0           | EMAC management data input output     | I/O  |
| EPHY0_25        | 25 MHz output for EMAC PHY            | O    |

Table 10-36 describes the pin list of RMII.

**Table 10- 36. EMAC RMII Pin List**

| Pin Name       | Description                       | Type |
|----------------|-----------------------------------|------|
| RMII0_TXD[1:0] | EMAC RMII transmit data           | O    |
| RMII0_TXEN     | EMAC RMII transmit enable         | O    |
| RMII0_RXCK     | EMAC RMII transmit clock          | I    |
| RMII0_RXD[1:0] | EMAC RMII receive data            | I    |
| RMII0_CRS_DV   | EMAC RMII receive data valid      | I    |
| RMII0_RXER     | EMAC RMII receive error           | I    |
| MDC0           | EMAC management data clock        | O    |
| MDIO0          | EMAC management data input output | I/O  |
| EPHY0_25       | 25 MHz output for EMAC PHY        | O    |

### 10.13.3.2. Clock Sources

Table 10-37 describes the clock of EMAC.

**Table 10- 37. EMAC Clock Characteristics**

| Clock Name             | Description                                                                        | Type |
|------------------------|------------------------------------------------------------------------------------|------|
| RGMII0_RXCK/RMII0_RXCK | In RGMII mode, output 2.5 MHz/25 MHz/125 MHz.<br>In RMII mode, input 5 MHz/50 MHz. | O/I  |
| RGMII0_RXCK            | In RGMII mode, input 2.5 MHz/25 MHz/125 MHz.<br>In RMII mode, no input.            | I    |

|              |                                                                      |   |
|--------------|----------------------------------------------------------------------|---|
| RGMII0_CLKIN | In RGMII mode, input 125M Reference Clock<br>In RMII mode, no clock. | I |
|--------------|----------------------------------------------------------------------|---|

### **10.13.3.3. Typical Application**



**Figure 10- 80. EMAC Typical Application**

#### **10.13.3.4. EMAC RX/TX Descriptor**

The internal DMA of EMAC transfers data between host memory and internal RX/TX FIFO with a linked list of descriptors. Each descriptor is consisted of four words, and contains some necessary information to transfer TX and RX frames. The descriptor list structure is shown in Figure 10-81. The address of each descriptor must be 32-bit aligned.



**Figure 10- 81. EMAC RX/TX Descriptor List**

### 10.13.3.5. Transmit Descriptor

#### 10.13.3.5.1. 1st Word of Transmit Descriptor

| Bits  | Description                                                                                                                                                                                      |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | TX_DESC_CTL<br>When set, current descriptor can be used by DMA. This bit is cleared by DMA when the whole frame is transmitted or all datas in the buffer of current descriptor are transmitted. |
| 30:17 | Reserved                                                                                                                                                                                         |
| 16    | TX_HEADER_ERR<br>When set, the checksum of header of transmitted frame is wrong.                                                                                                                 |
| 15    | Reserved                                                                                                                                                                                         |
| 14    | TX_LENGTH_ERR<br>When set, the length of transmitted frame is wrong.                                                                                                                             |
| 13    | Reserved                                                                                                                                                                                         |
| 12    | TX_PAYLOAD_ERR<br>When set, the checksum of payload of transmitted frame is wrong.                                                                                                               |
| 11    | Reserved                                                                                                                                                                                         |
| 10    | TX_CRS_ERR<br>When set, carrier is lost during transmission.                                                                                                                                     |
| 9     | TX_COL_ERR_0<br>When set, the frame is aborted because of collision after contention period.                                                                                                     |
| 8     | TX_COL_ERR_1<br>When set, the frame is aborted because of too many collisions.                                                                                                                   |
| 7     | Reserved                                                                                                                                                                                         |
| 6:3   | TX_COL_CNT<br>The number of collisions before transmission.                                                                                                                                      |
| 2     | TX_DEFER_ERR<br>When set, the frame is aborted because of too much deferral.                                                                                                                     |
| 1     | TX_UNDERFLOW_ERR<br>When set, the frame is aborted because of TX FIFO underflow error.                                                                                                           |
| 0     | TX_DEFER<br>When set in Half-Duplex mode, the EMAC defers the frame transmission.                                                                                                                |

#### 10.13.3.5.2. 2nd Word of Transmit Descriptor

| Bits | Description                                                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------|
| 31   | TX_INT_CTL<br>When set and the current frame have been transmitted, the TX_INT in Interrupt Status Register will be set. |
| 30   | LAST_DESC<br>When set, current descriptor is the last one for current frame.                                             |
| 29   | FIR_DESC                                                                                                                 |

|       |                                                                           |
|-------|---------------------------------------------------------------------------|
|       | When set, current descriptor is the first one for current frame.          |
| 28:27 | CHECKSUM_CTL<br>These bits control to insert checksums in transmit frame. |
| 26    | CRC_CTL<br>When set, CRC field is not transmitted.                        |
| 25:11 | Reserved                                                                  |
| 10:0  | BUF_SIZE<br>The size of buffer specified by current descriptor.           |

#### 10.13.3.5.3. 3rd Word of Transmit Descriptor

| Bits | Description                                                        |
|------|--------------------------------------------------------------------|
| 31:0 | BUF_ADDR<br>The address of buffer specified by current descriptor. |

#### 10.13.3.5.4. 4th Word of Transmit Descriptor

| Bits | Description                                                                  |
|------|------------------------------------------------------------------------------|
| 31:0 | NEXT_DESC_ADDR<br>The address of next descriptor. It must be 32-bit aligned. |

#### 10.13.3.6. Receive Descriptor

##### 10.13.3.6.1. 1st Word of Receive Descriptor

| Bits  | Description                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | RX_DESC_CTL<br>When setting the bit, the current descriptor can be used by DMA. This bit is cleared by DMA when the complete frame is received or the buffer of current descriptor is full.                                                              |
| 30    | RX_DAF_FAIL<br>When setting the bit, the current frame does not pass DA filter.                                                                                                                                                                          |
| 29:16 | RX_FRM_LEN<br>When LAST_DESC is not set and no error bit is set, this field is the length of received data for current frame.<br>When LAST_DESC is set, RX_OVERFLOW_ERR and RX_NO_ENOUGH_BUF_ERR are not set, this field is the length of receive frame. |
| 15    | Reserved                                                                                                                                                                                                                                                 |
| 14    | RX_NO_ENOUGH_BUF_ERR<br>When setting the bit, the current frame is clipped because of no enough buffer.                                                                                                                                                  |
| 13    | RX_SAF_FAIL<br>When setting the bit, the current frame does not pass SA filter.                                                                                                                                                                          |

|    |                                                                                                           |
|----|-----------------------------------------------------------------------------------------------------------|
| 12 | Reserved                                                                                                  |
| 11 | RX_OVERFLOW_ERR<br>When setting the bit, a buffer overflow error occurred and current frame is wrong.     |
| 10 | Reserved                                                                                                  |
| 9  | FIR_DESC<br>When setting the bit, current descriptor is the first descriptor for current frame.           |
| 8  | LAST_DESC<br>When setting the bit, current descriptor is the last descriptor for current frame.           |
| 7  | RX_HEADER_ERR<br>When setting the bit, the checksum of the frame header is wrong.                         |
| 6  | RX_COL_ERR<br>When setting the bit, there is a late collision during reception in half-duplex mode.       |
| 5  | Reserved                                                                                                  |
| 4  | RX_LENGTH_ERR<br>When setting the bit, the length of current frame is wrong.                              |
| 3  | RX_PHY_ERR<br>When setting the bit, the receive error signal from PHY is asserted during reception.       |
| 2  | Reserved                                                                                                  |
| 1  | RX_CRC_ERR<br>When setting the bit, the CRC field of received frame is wrong.                             |
| 0  | RX_PAYLOAD_ERR<br>When setting the bit, the checksum or length of the payload of received frame is wrong. |

#### 10.13.3.6.2. 2nd Word of Receive Descriptor

| Bits  | Description                                                                                    |
|-------|------------------------------------------------------------------------------------------------|
| 31    | RX_INT_CTL<br>When setting the bit, and a frame has been received, the RX_INT will not be set. |
| 30:11 | Reserved                                                                                       |
| 10:0  | BUF_SIZE<br>The size of buffer is specified by current descriptor.                             |

#### 10.13.3.6.3. 3rd Word of Receive Descriptor

| Bits | Description                                                        |
|------|--------------------------------------------------------------------|
| 31:0 | BUF_ADDR<br>The address of buffer specified by current descriptor. |

#### 10.13.3.6.4. 4th Word of Receive Descriptor

| Bits | Description                                                                          |
|------|--------------------------------------------------------------------------------------|
| 31:0 | NEXT_DESC_ADDR<br>The address of next descriptor. This field must be 32-bit aligned. |

#### 10.13.4. Register List

| Module Name | Base Address |
|-------------|--------------|
| EMAC0       | 0x05020000   |

| Register Name         | Offset               | Description                                    |
|-----------------------|----------------------|------------------------------------------------|
| EMAC_BASIC_CTL0       | 0x0000               | EMAC Basic Control Register0                   |
| EMAC_BASIC_CTL1       | 0x0004               | EMAC Basic Control Register1                   |
| EMAC_INT_STA          | 0x0008               | EMAC Interrupt Status Register                 |
| EMAC_INT_EN           | 0x000C               | EMAC Interrupt Enable Register                 |
| EMAC_TX_CTL0          | 0x0010               | EMAC Transmit Control Register0                |
| EMAC_TX_CTL1          | 0x0014               | EMAC Transmit Control Register1                |
| EMAC_TX_FLOW_CTL      | 0x001C               | EMAC Transmit Flow Control Register            |
| EMAC_TX_DMA_DESC_LIST | 0x0020               | EMAC Transmit Descriptor List Address Register |
| EMAC_RX_CTL0          | 0x0024               | EMAC Receive Control Register0                 |
| EMAC_RX_CTL1          | 0x0028               | EMAC Receive Control Register1                 |
| EMAC_RX_DMA_DESC_LIST | 0x0034               | EMAC Receive Descriptor List Address Register  |
| EMAC_RX_FRM_FLT       | 0x0038               | EMAC Receive Frame Filter Register             |
| EMAC_RX_HASH0         | 0x0040               | EMAC Hash Table Register0                      |
| EMAC_RX_HASH1         | 0x0044               | EMAC Hash Table Register1                      |
| EMAC_MII_CMD          | 0x0048               | EMAC Management Interface Command Register     |
| EMAC_MII_DATA         | 0x004C               | EMAC Management Interface Data Register        |
| EMAC_ADDR_HIGH0       | 0x0050               | EMAC MAC Address High Register0                |
| EMAC_ADDR_LOW0        | 0x0054               | EMAC MAC Address Low Register0                 |
| EMAC_ADDR_HIGHx       | 0x0050+0x08*N(N=1~7) | EMAC MAC Address High RegisterN(N:1~7)         |
| EMAC_ADDR_LOWx        | 0x0054+0x08*N(N=1~7) | EMAC MAC Address Low RegisterN(N:1~7)          |
| EMAC_TX_DMA_STA       | 0x00B0               | EMAC Transmit DMA Status Register              |
| EMAC_TX_CUR_DESC      | 0x00B4               | EMAC Current Transmit Descriptor Register      |
| EMAC_TX_CUR_BUF       | 0x00B8               | EMAC Current Transmit Buffer Address Register  |
| EMAC_RX_DMA_STA       | 0x00C0               | EMAC Receive DMA Status Register               |
| EMAC_RX_CUR_DESC      | 0x00C4               | EMAC Current Receive Descriptor Register       |
| EMAC_RX_CUR_BUF       | 0x00C8               | EMAC Current Receive Buffer Address Register   |
| EMAC_RGMII_STA        | 0x00D0               | EMAC RGMII Status Register                     |

### 10.13.5. Register Description

#### 10.13.5.1. 0x0000 EMAC Basic Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: EMAC_BASIC_CTL0                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:4           | /          | /           | /                                                                           |
| 3:2            | R/W        | 0x0         | SPEED<br>00: 1000 Mbit/s<br>01: Reserved<br>10: 10 Mbit/s<br>11: 100 Mbit/s |
| 1              | R/W        | 0x0         | LOOPBACK<br>0: Disable<br>1: Enable                                         |
| 0              | R/W        | 0x0         | DUPLEX<br>0: Half-duplex<br>1: Full-duplex                                  |

#### 10.13.5.2. 0x0004 EMAC Basic Control Register1 (Default Value: 0x0800\_0000)

| Offset: 0x0004 |            |             | Register Name: EMAC_BASIC_CTL1                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                 |
| 29:24          | R/W        | 0x8         | BURST_LEN<br>The burst length of RX and TX DMA transfer.                                                                                                                                                                                                          |
| 23:2           | /          | /           | /                                                                                                                                                                                                                                                                 |
| 1              | R/W        | 0x0         | RX_TX_PRI<br>RX TX DMA Priority<br>0: Same priority<br>1: RX priority over TX                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | SOFT_RST<br>Soft Reset all Registers and Logic<br>0: No valid<br>1: Reset<br>All clock inputs must be valid before soft reset. This bit is cleared internally when the reset operation is completed fully. Before writing any register, this bit should read a 0. |

#### 10.13.5.3. 0x0008 EMAC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 | Register Name: EMAC_INT_STA |
|----------------|-----------------------------|
|----------------|-----------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                               |
|-------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:17 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                         |
| 16    | R/W1C      | 0x0         | <b>RGMII_LINK_STA_P</b><br>RMII Link Status Changed Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                                                            |
| 15:14 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                         |
| 13    | R/W1C      | 0x0         | <b>RX_EARLY_P</b><br>RX DMA Filled First Data Buffer of the Receive Frame Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                                      |
| 12    | R/W1C      | 0x0         | <b>RX_OVERFLOW_P</b><br>RX FIFO Overflow Error Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                                                                 |
| 11    | R/W1C      | 0x0         | <b>RX_TIMEOUT_P</b><br>RX Timeout Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it. When this bit asserted, the length of receive frame is greater than 2048 bytes(10240 when JUMBO_FRM_EN is set)                                                                                                                                               |
| 10    | R/W1C      | 0x0         | <b>RX_DMA_STOPPED_P</b><br>When this bit asserted, the RX DMA FSM is stopped.                                                                                                                                                                                                                                                                                             |
| 9     | R/W1C      | 0x0         | <b>RX_BUF_UA_P</b><br>RX Buffer UA Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it. When this asserted, the RX DMA cannot acquire next RX descriptor and RX DMA FSM is suspended. The ownership of next RX descriptor should be changed to RX DMA. The RX DMA FSM will resume when writing to RX_DMA_START bit or next receive frame is coming. |
| 8     | R/W1C      | 0x0         | <b>RX_P</b><br>Frame RX Completed Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it. When this bit is asserted, a frame reception is completed. The RX DMA FSM remains in the running state.                                                                                                                                                      |
| 7:6   | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                         |
| 5     | R/W1C      | 0x0         | <b>TX_EARLY_P</b><br>Frame is transmitted to FIFO totally Interrupt Pending<br>0: No Pending<br>1: Pending                                                                                                                                                                                                                                                                |

|   |       |     |                                                                                                                                                                                                                                                                                                                            |
|---|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |       |     | Write '1' to clear it.                                                                                                                                                                                                                                                                                                     |
| 4 | R/W1C | 0x0 | <b>TX_UNDERFLOW_P</b><br>TX FIFO Underflow Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                      |
| 3 | R/W1C | 0x0 | <b>TX_TIMEOUT_P</b><br>Transmitter Timeout Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                      |
| 2 | R/W1C | 0x0 | <b>TX_BUF_UA_P</b><br>TX Buffer UA Interrupt Pending<br>0: No Pending<br>1: Pending<br>When this asserted, the TX DMA can not acquire next TX descriptor and TX DMA FSM is suspended. The ownership of next TX descriptor should be changed to TX DMA. The TX DMA FSM will resume when writing to <b>TX_DMA_START</b> bit. |
| 1 | R/W1C | 0x0 | <b>TX_DMA_STOPPED_P</b><br>Transmission DMA Stopped Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                             |
| 0 | R/W1C | 0x0 | <b>TX_P</b><br>Frame Transmission Interrupt Pending<br>0: No Pending<br>1: Pending<br>Write '1' to clear it.                                                                                                                                                                                                               |

#### 10.13.5.4. 0x000C EMAC Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: EMAC_INT_EN                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:14          | /          | /           | /                                                                                  |
| 13             | R/W        | 0x0         | <b>RX_EARLY_INT_EN</b><br>Early Receive Interrupt<br>0: Disable<br>1: Enable       |
| 12             | R/W        | 0x0         | <b>RX_OVERFLOW_INT_EN</b><br>Receive Overflow Interrupt<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | <b>RX_TIMEOUT_INT_EN</b>                                                           |

|     |     |     |                                                                                        |
|-----|-----|-----|----------------------------------------------------------------------------------------|
|     |     |     | Receive Timeout Interrupt<br>0: Disable<br>1: Enable                                   |
| 10  | R/W | 0x0 | RX_DMA_STOPPED_INT_EN<br>Receive DMA FSM Stopped Interrupt<br>0: Disable<br>1: Enable  |
| 9   | R/W | 0x0 | RX_BUF_UA_INT_EN<br>Receive Buffer Unavailable Interrupt<br>0: Disable<br>1: Enable    |
| 8   | R/W | 0x0 | RX_INT_EN<br>Receive Interrupt<br>0: Disable<br>1: Enable                              |
| 7:6 | /   | /   | /                                                                                      |
| 5   | R/W | 0x0 | TX_EARLY_INT_EN<br>Early Transmit Interrupt<br>0: Disable<br>1: Enable                 |
| 4   | R/W | 0x0 | TX_UNDERFLOW_INT_EN<br>Transmit Underflow Interrupt<br>0: Disable<br>1: Enable         |
| 3   | R/W | 0x0 | TX_TIMEOUT_INT_EN<br>Transmit Timeout Interrupt<br>0: Disable<br>1: Enable             |
| 2   | R/W | 0x0 | TX_BUF_UA_INT_EN<br>Transmit Buffer Available Interrupt<br>0: Disable<br>1: Enable     |
| 1   | R/W | 0x0 | TX_DMA_STOPPED_INT_EN<br>Transmit DMA FSM Stopped Interrupt<br>0: Disable<br>1: Enable |
| 0   | R/W | 0x0 | TX_INT_EN<br>Transmit Interrupt<br>0: Disable<br>1: Enable                             |

#### 10.13.5.5. 0x0010 EMAC Transmit Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0010 | Register Name: EMAC_TX_CTL0 |
|----------------|-----------------------------|
|----------------|-----------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
|------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | R/W        | 0x0         | <b>TX_EN</b><br>Enable Transmitter<br>0: Disable<br>1: Enable<br>When disable, the transmit will continue until the current transmit finishes.                                                        |
| 30   | R/W        | 0x0         | <b>TX_FRM_LEN_CTL</b><br>Frame Transmit Length Control<br>0: Up to 2,048 bytes (JUMBO_FRM_EN==0)<br>Up to 10,240 bytes (JUMBO_FRM_EN==1)<br>1: Up to 16,384 bytes<br>Any bytes after that is cut off. |
| 29:0 | /          | /           | /                                                                                                                                                                                                     |

#### 10.13.5.6. 0x0014 EMAC Transmit Control Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: EMAC_TX_CTL1                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 31             | R/W        | 0x0         | <b>TX_DMA_START</b><br>Transmit DMA FSM Start<br>0: No valid<br>1: Start<br>It is cleared internally and always read a 0.                                                                                                                                                                                                        |
| 30             | R/W        | 0x0         | <b>TX_DMA_EN</b><br>0: Stop TX DMA after the completion of current frame transmission<br>1: Start and run TX DMA                                                                                                                                                                                                                 |
| 29:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                |
| 10:8           | R/W        | 0x0         | <b>TX_TH</b><br>Threshold value of TX DMA FIFO<br>When TX_MD is 0, transmission starts when the size of frame in TX DMA FIFO is greater than the threshold. In addition, the full frames with a length less than the threshold are transferred automatically.<br>000: 64<br>001: 128<br>010: 192<br>011: 256<br>Others: Reserved |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                |
| 1              | R/W        | 0x0         | <b>TX_MD</b><br>Transmission Mode<br>0: TX start after TX DMA FIFO bytes is greater than TX_TH<br>1: TX start after TX DMA FIFO located a full frame                                                                                                                                                                             |
| 0              | R/W        | 0x0         | <b>FLUSH_TX_FIFO</b><br>Flush the data in the TX FIFO                                                                                                                                                                                                                                                                            |

|  |  |  |                         |
|--|--|--|-------------------------|
|  |  |  | 0: Enable<br>1: Disable |
|--|--|--|-------------------------|

#### 10.13.5.7. 0x001C EMAC Transmit Flow Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: EMAC_TX_FLOW_CTL                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                               |
| 31             | R/W        | 0x0         | <p><b>TX_FLOW_CTL_STA</b><br/>           This bit indicates a pause frame transmission is in progress. When the configuration of flow control is ready, set this bit to transmit a pause frame in full-duplex mode or activate the backpressure function. After completion of transmission, this bit will be cleared automatically. Before writing register TX_FLOW_CTRL, this bit must be read as 0.</p> |
| 30:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21:20          | R/W        | 0x0         | <p><b>TX_PAUSE_FRM_SLOT</b><br/>           The threshold of the pause timer at which the input flow control signal is checked for automatic retransmission of pause frame. The threshold values should be always less than the PAUSE_TIME.</p>                                                                                                                                                            |
| 19:4           | R/W        | 0x0         | <p><b>PAUSE_TIME</b><br/>           The pause time field in the transmitted control frame.</p>                                                                                                                                                                                                                                                                                                            |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1              | R/W        | 0x0         | <p><b>ZQP_FRM_EN</b><br/>           0: Disable<br/>           1: Enable<br/>           When set, enable the functionality to generate Zero-Quanta Pause control frame.</p>                                                                                                                                                                                                                                |
| 0              | R/W        | 0x0         | <p><b>TX_FLOW_CTL_EN</b><br/> <b>TX Flow Control Enable</b><br/>           0: Disable<br/>           1: Enable<br/>           When set, enable flow control operation to transmit pause frames in full-duplex mode, or enable the back-pressure operation in half-duplex mode.</p>                                                                                                                        |

#### 10.13.5.8. 0x0020 EMAC Transmit DMA Descriptor List Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: EMAC_TX_DMA_LIST                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31:0           | R/W        | 0x0         | <p><b>TX_DESC_LIST</b><br/>           The base address of transmit descriptor list. It must be 32-bit aligned.</p> |

**10.13.5.9. 0x0024 EMAC Receive Control Register0 (Default Value: 0x0000\_0000)**

| Offset: 0x0024 |            |             | Register Name: EMAC_RX_CTL0                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0x0         | RX_EN<br>Enable Receiver<br>0: Disable receiver after current reception<br>1: Enable                                                                                                                                                                                                                |
| 30             | R/W        | 0x0         | RX_FRM_LEN_CTL<br>Frame Receive Length Control<br>0: Up to 2,048 bytes (JUMBO_FRM_EN==0)<br>Up to 10,240 bytes (JUMBO_FRM_EN==1)<br>1: Up to 16,384 bytes<br>Any bytes after that is cut off                                                                                                        |
| 29             | R/W        | 0x0         | JUMBO_FRM_EN<br>Jumbo Frame Enable<br>0: Disable<br>1: Enable Jumbo frames of 9,018 bytes without reporting a giant                                                                                                                                                                                 |
| 28             | R/W        | 0x0         | STRIP_FCS<br>When set, strip the Pad/FCS field on received frames only when the length's field value is less than or equal to 1,500 bytes.                                                                                                                                                          |
| 27             | R/W        | 0x0         | CHECK_CRC<br>Check CRC Enable<br>0: Disable<br>1: Calculate CRC and check the IPv4 Header Checksum                                                                                                                                                                                                  |
| 26:18          | /          | /           | /                                                                                                                                                                                                                                                                                                   |
| 17             | R/W        | 0x0         | RX_PAUSE_FRM_MD<br>0: Only detect multicast pause frame specified in the 802.3x standard.<br>1: In addition to detect multicast pause frame specified in the 802.3x standard, also detect unicast pause frame with address specified in MAC Address 0 High Register and MAC address 0 Low Register. |
| 16             | R/W        | 0x0         | RX_FLOW_CTL_EN<br>When set, enable the functionality that decode the received pause frame and disable its transmitter for a specified time by pause frame.                                                                                                                                          |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                   |

**10.13.5.10. 0x0028 EMAC Receive Control Register1 (Default Value: 0x0000\_0000)**

| Offset: 0x0028 |            |             | Register Name: EMAC_RX_CTL1                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | RX_DMA_START<br>When set, the RX DMA will not work. It is cleared internally and always read a 0. |

|       |     |     |                                                                                                                                                                                                                            |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30    | R/W | 0x0 | <b>RX_DMA_EN</b><br>Receive DMA Enable<br>0: Stop RX DMA after finish receiving current frame<br>1: Start and run RX DMA                                                                                                   |
| 29:25 | /   | /   | /                                                                                                                                                                                                                          |
| 24    | R/W | 0x0 | <b>RX_FIFO_FLOW_CTL</b><br>Receive FIFO Flow Control Enable<br>0: Disable<br>1: Enable, base on RX_FLOW_CTL_TH_DEACT and RX_FLOW_CTL_TH_ACT                                                                                |
| 23:22 | R/W | 0x0 | <b>RX_FLOW_CTL_TH_DEACT</b><br>Threshold for Deactivating Flow Control<br>00: Full minus 1 KB<br>01: Full minus 2 KB<br>10: Full minus 3 KB<br>11: Full minus 4 KB<br>Valid in both half-duplex mode and full-duplex mode. |
| 21:20 | R/W | 0x0 | <b>RX_FLOW_CTL_TH_ACT</b><br>Threshold for Activating Flow Control<br>00: Full minus 1 KB<br>01: Full minus 2 KB<br>10: Full minus 3 KB<br>11: Full minus 4 KB<br>Valid in both half-duplex mode and full-duplex mode.     |
| 19:6  | /   | /   | /                                                                                                                                                                                                                          |
| 5:4   | R/W | 0x0 | <b>RX_TH</b><br>Threshold for RX DMA FIFO Start<br>00: 64<br>01: 32<br>10: 96<br>11: 128<br><b>Note: Only valid when RX_MD == 0, the full frames with a length less than the threshold are transferred automatically.</b>  |
| 3     | R/W | 0x0 | <b>RX_ERR_FRM</b><br>0: RX DMA drops frames with error<br>1: RX DMA forwards frames with error                                                                                                                             |
| 2     | R/W | 0x0 | <b>RX_RUNT_FRM</b><br>When setting, forward undersized frames with no error and length less than 64bytes                                                                                                                   |
| 1     | R/W | 0x0 | <b>RX_MD</b><br>Receive Mode<br>0: RX start read after RX DMA FIFO bytes is greater than RX_TH<br>1: RX start read after RX DMA FIFO located a full frame                                                                  |
| 0     | R/W | 0x0 | <b>FLUSH_RX_FRM</b><br>Flush Receive Frames<br>0: Enable when receive descriptors/buffers is unavailable                                                                                                                   |

|  |  |            |
|--|--|------------|
|  |  | 1: Disable |
|--|--|------------|

#### 10.13.5.11. 0x0034 EMAC Receive DMA Descriptor List Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: EMAC_RX_DMA_LIST                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:0           | R/W        | 0x0         | RX_DESC_LIST<br>The base address of receive descriptor list. It must be 32-bit aligned. |

#### 10.13.5.12. 0x0038 EMAC Receive Frame Filter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: EMAC_RX_FRM_FILT                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31             | R/W        | 0x0         | DIS_ADDR_FILTER<br>Disable Address Filter<br>0: Enable<br>1: Disable                                                                                                                                           |
| 30:18          | /          | /           | /                                                                                                                                                                                                              |
| 17             | R/W        | 0x0         | DIS_BROADCAST<br>Disable Receive Broadcast Frames<br>0: Receive<br>1: Drop                                                                                                                                     |
| 16             | R/W        | 0x0         | RX_ALL_MULTICAST<br>Receive All Multicast Frames Filter<br>0: Filter according to HASH_MULTICAST<br>1: Receive all                                                                                             |
| 15:14          | /          | /           | /                                                                                                                                                                                                              |
| 13:12          | R/W        | 0x0         | CTL_FRM_FILTER<br>Receive Control Frames Filter<br>00: Drop all control frames<br>01: Drop all control frames<br>10: Receive all control frames<br>11: Receive all control frames when pass the address filter |
| 11:10          | /          | /           | /                                                                                                                                                                                                              |
| 9              | R/W        | 0x0         | HASH_MULTICAST<br>Filter Multicast Frames Set<br>0: By comparing the DA field in DA MAC address registers<br>1: According to the hash table                                                                    |
| 8              | R/W        | 0x0         | HASH_UNICAST<br>Filter Unicast Frames Set<br>0: By comparing the DA field in DA MAC address registers<br>1: According to the hash table                                                                        |

|     |     |     |                                                                                                                                                                                                                                                                                |
|-----|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | /   | /   | /                                                                                                                                                                                                                                                                              |
| 6   | R/W | 0x0 | <p><b>SA_FILTER_EN</b><br/>Receive SA Filter Enable<br/>0: Receive frames and update the result of SA filter<br/>1: Update the result of SA filter. In addition, if the SA field of received frame does not match the values in SA MAC address registers, drop this frame.</p> |
| 5   | R/W | 0x0 | <p><b>SA_INV_FILTER</b><br/>Receive SA Invert Filter Set<br/>0: Pass frames whose SA field matches SA MAC address registers<br/>1: Pass frames whose SA field not matches SA MAC address registers</p>                                                                         |
| 4   | R/W | 0x0 | <p><b>DA_INV_FILTER</b><br/>0: Normal filtering of frames is performed<br/>1: Filter both unicast and multicast frames by comparing DA field in inverse filtering mode</p>                                                                                                     |
| 3:2 | /   | /   | /                                                                                                                                                                                                                                                                              |
| 1   | R/W | 0x0 | <p><b>FLT_MD</b><br/>0: If the HASH_MULTICAST or HASH_UNICAST is set, the frame is passed only when it matches the Hash filter<br/>1: Receive the frame when it passes the address register filter or the hash filter(set by HASH_MULTICAST or HASH_UNICAST)</p>               |
| 0   | R/W | 0x0 | <p><b>RX_ALL</b><br/>Receive All Frame Enable<br/>0: Receive the frames that pass the SA/DA address filter<br/>1: Receive all frames and update the result of address filter(pass or fail) in the receive status word</p>                                                      |

#### 10.13.5.13. 0x0040 EMAC Receive Hash Table Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: EMAC_RX_HASH0                                           |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R/W        | 0x0         | HASH_TAB0<br>The upper 32 bits of Hash table for receive frame filter. |

#### 10.13.5.14. 0x0044 EMAC Receive Hash Table Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: EMAC_RX_HASH1                                           |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R/W        | 0x0         | HASH_TAB1<br>The lower 32 bits of Hash table for receive frame filter. |

**10.13.5.15. 0x0048 EMAC MII Command Register (Default Value: 0x0000\_0000)**

| Offset: 0x0048 |            |             | Register Name: EMAC_MII_CMD                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:23          | /          | /           | /                                                                                                                                                               |
| 22:20          | R/W        | 0x0         | MDC_DIV_RATIO_M<br>MDC Clock Divide Ratio<br>000: 16<br>001: 32<br>010: 64<br>011: 128<br>Others: Reserved<br><b>Note: MDC Clock is divided from AHB clock.</b> |
| 19:17          | /          | /           | /                                                                                                                                                               |
| 16:12          | R/W        | 0x0         | PHY_ADDR<br>PHY Address                                                                                                                                         |
| 11:9           | /          | /           | /                                                                                                                                                               |
| 8:4            | R/W        | 0x0         | PHY_REG_ADDR<br>PHY Register Address                                                                                                                            |
| 3:2            | /          | /           | /                                                                                                                                                               |
| 1              | R/W        | 0x0         | MII_WR<br>MII Write and Read<br>0: Read<br>1: Write                                                                                                             |
| 0              | R/W        | 0x0         | MII_BUSY<br>0: Write no valid, read 0 indicates finish in read or write operation<br>1: Write start read or write operation, read 1 indicates busy.             |

**10.13.5.16. 0x004C EMAC MII Data Register (Default Value: 0x0000\_0000)**

| Offset: 0x004C |            |             | Register Name: EMAC_MII_DATA                                        |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:16          | /          | /           | /                                                                   |
| 15:0           | R/W        | 0x0         | MII_DATA<br>Write to or read from the register in the selected PHY. |

**10.13.5.17. 0x0050 EMAC MAC Address High Register0 (Default Value: 0x0000\_FFFF)**

| Offset: 0x0050 |            |             | Register Name: EMAC_ADDR_HIGH0 |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:16          | /          | /           | /                              |
| 15:0           | R/W        | 0xFFFF      | MAC_ADDR_HIGH0                 |

|  |  |                                           |
|--|--|-------------------------------------------|
|  |  | The upper 16 bits of the 1st MAC address. |
|--|--|-------------------------------------------|

#### 10.13.5.18. 0x0054 EMAC MAC Address Low Register0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0054 |            |             | Register Name: EMAC_ADDR_LOW0                          |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:0           | R/W        | 0xFFFFFFFF  | MAC_ADDR_LOW0<br>The lower 32 bits of 1st MAC address. |

#### 10.13.5.19. 0x0050+0x08\*N EMAC MAC Address High Register N (Default Value: 0x0000\_0000)

| Offset: 0x0050+0x08*N (N=1~7) |            |             | Register Name: EMAC_ADDR_HIGHN                                                                                                                                                        |
|-------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31                            | R/W        | 0x0         | MAC_ADDR_CTL<br>MAC Address Valid<br>0: Not valid<br>1: Valid                                                                                                                         |
| 30                            | R/W        | 0x0         | MAC_ADDR_TYPE<br>MAC Address Type<br>0: Used to compare with the destination address of the received frame<br>1: Used to compare with the source address of the received frame        |
| 29:24                         | R/W        | 0x0         | MAC_ADDR_BYTE_CTL<br>MAC Address Byte Control Mask<br>The lower bit of mask controls the lower byte of MAC address. When the bit of mask is 1, do not compare the corresponding byte. |
| 23:16                         | /          | /           | /                                                                                                                                                                                     |
| 15:0                          | R/W        | 0x0         | MAC_ADDR_HIGH<br>The upper 16 bits of the MAC address.                                                                                                                                |

#### 10.13.5.20. 0x0054+0x08\*N EMAC MAC Address Low Register N (Default Value: 0x0000\_0000)

| Offset: 0x0054+0x08*N (N=1~7) |            |             | Register Name: EMAC_ADDR_LOWN                                 |
|-------------------------------|------------|-------------|---------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                   |
| 31:0                          | R/W        | 0x0         | MAC_ADDR_LOWN<br>The lower 32 bits of MAC address N (N: 1~7). |

#### 10.13.5.21. 0x00B0 EMAC Transmit DMA Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: EMAC_TX_DMA_STA |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |

|      |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|---|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:3 | / | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2:0  | R | 0x0 | <p>TX_DMA_STA<br/>                     The State of Transmit DMA FSM<br/>                     000: STOP, when reset or disable TX DMA<br/>                     001: RUN_FETCH_DESC, fetching TX DMA descriptor<br/>                     010: RUN_WAIT_STA, waiting for the status of TX frame<br/>                     011: RUN_TRANS_DATA, passing frame from host memory to TX DMA FIFO<br/>                     100: Reserved<br/>                     101: Reserved<br/>                     111: RUN_CLOSE_DESC, closing TX descriptor<br/>                     110: SUSPEND, TX descriptor unavailable or TX DMA FIFO underflow</p> |

#### 10.13.5.22. 0x00B4 EMAC Transmit DMA Current Descriptor Register (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: EMAC_TX_DMA_CUR_DESC         |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:0           | R          | 0x0         | The address of current transmit descriptor. |

#### 10.13.5.23. 0x00B8 EMAC Transmit DMA Current Buffer Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: EMAC_TX_DMA_CUR_BUF          |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:0           | R          | 0x0         | The address of current transmit DMA buffer. |

#### 10.13.5.24. 0x00C0 EMAC Receive DMA Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: EMAC_RX_DMA_STA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2:0            | R          | 0x0         | <p>RX_DMA_STA<br/>                     The State of RX DMA FSM<br/>                     000: STOP, when reset or disable RX DMA<br/>                     001: RUN_FETCH_DESC, fetching RX DMA descriptor<br/>                     010: Reserved<br/>                     011: RUN_WAIT_FRM, waiting for frame<br/>                     100: SUSPEND, RX descriptor unavailable<br/>                     101: RUN_CLOSE_DESC, closing RX descriptor<br/>                     110: Reserved<br/>                     111: RUN_TRANS_DATA, passing frame from host memory to RX DMA FIFO</p> |

**10.13.5.25. 0x00C4 EMAC Receive DMA Current Descriptor Register (Default Value: 0x0000\_0000)**

| Offset: 0x00C4 |            |             | Register Name: EMAC_RX_DMA_CUR_DESC       |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:0           | R          | 0x0         | The address of current receive descriptor |

**10.13.5.26. 0x00C8 EMAC Receive DMA Current Buffer Address Register (Default Value: 0x0000\_0000)**

| Offset: 0x00C8 |            |             | Register Name: EMAC_RX_DMA_CUR_BUF        |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:0           | R          | 0x0         | The address of current receive DMA buffer |

**10.13.5.27. 0x00D0 EMAC RGMII Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x00D0 |            |             | Register Name: EMAC_RGMII_STA                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:4           | /          | /           | /                                                                                                                      |
| 3              | R          | 0x0         | <b>RGMII_LINK</b><br>The link status of RGMII interface<br>0: down<br>1: up                                            |
| 2:1            | R          | 0x0         | <b>RGMII_LINK_SPD</b><br>The link speed of RGMII interface<br>00: 2.5 MHz<br>01: 25 MHz<br>10: 125 MHz<br>11: Reserved |
| 0              | R          | 0x0         | <b>RGMII_LINK_MD</b><br>The link mode of RGMII interface<br>0: Half-Duplex<br>1: Full-Duplex                           |

## Contents

|                                                      |      |
|------------------------------------------------------|------|
| Chapter 11 Security System .....                     | 1041 |
| 11.1. Crypto Engine .....                            | 1041 |
| 11.1.1. Overview .....                               | 1041 |
| 11.1.2. Block Diagram .....                          | 1042 |
| 11.1.3. Operations and Functional Descriptions ..... | 1043 |
| 11.1.4. Register List .....                          | 1053 |
| 11.1.5. Register Description .....                   | 1053 |
| 11.2. Security ID .....                              | 1059 |

Confidential

## Figures

---

|                                                                                         |      |
|-----------------------------------------------------------------------------------------|------|
| Figure 11- 1. CE Block Diagram .....                                                    | 1042 |
| Figure 11- 2. Task Chaining of Hash Algorithms and Random Bit Generator Algorithms..... | 1044 |
| Figure 11- 3. Task Chaining of Symmetrical Algorithms and Asymmetrical Algorithms ..... | 1047 |

Confidential

# Chapter 11 Security System

## 11.1. Crypto Engine

### 11.1.1. Overview

The Crypto Engine(CE) module is one encryption/decryption algorithm accelerator. It supports kinds of symmetric, asymmetric, Hash, and RNG algorithms. There are two software interfaces for secure and non-secure world each. The software interface is simple for configuration, only setting interrupt control, task description address and load tag. Algorithm control information is written in memory by task descriptor, then CE automatically reads it when executing request. It supports parallel requests from 4 channels, and has an internal DMA controller to transfer data between CE and memory.

The CE has the following features:

- Symmetrical algorithms
  - Supports AES, XTS-AES, DES, 3DES, SM4
  - 128-, 192-, 256-bit key size for AES
  - ECB, CBC, CTR, CTS, OFB, CFB, CBC-MAC, GCM modes for AES
  - AES-CFB mode support CFB1, CFB8, CFB64, CFB128
  - AES-CTR supports CTR16, CTR32, CTR64, CTR128
  - 256-bit, 512-bit key for XTS-AES
  - ECB, CBC, CTR, CBC-MAC modes for DES
  - DES-CTR mode supports CTR16, CTR32, CTR64
- Hash algorithms
  - Supports MD5, SHA1, SHA224, SHA256, SHA384, SHA512, SM3, HMAC-SHA1, HMAC-SHA256
  - Supports hardware padding
- Asymmetrical algorithms
  - Supports RSA, ECC, SM2
  - RSA512/1024/2048/3072/4096-bit
  - ECC160/224/256/384/521-bit
- Random bit generator(RBG) algorithms
  - Hardware PRNG with 175-bit seed width. Output aligns with 5 words
  - Hardware TRNG. Output aligns with 8 words
  - HASH-DRBG (SHA1, SHA256, SHA512)
  - Instantiate/Reseed/Generate/Uninstantiate 4 process
  - prediction resistance requests

- 8 separate suits of internal state
- Maximum  $2^{32}$  BYTE length of Entropy input, Nonce, Personalization, Additional input, and length is multiple of word
- Security strategy and system feature
  - Symmetric, asymmetric, HASH/RBG ctrl logics are separate, which can handle task simultaneously. Symmetric logic can select instantiate 2 suits at implementation time
  - Supports task chain mode for each request. Task or task chain are executed at request order
  - 8 scatter group(sg) are supported for both input and output data
  - Supports secure and non-secure interfaces respectively, each world issues task request through its own interface, donot know the existence of each other
  - Each world has 4 channels for software request, each channel has an interrupt control and status bit, and channels are independent with each other

### 11.1.2. Block Diagram

The following figure shows the block diagram of Crypto Engine.



Figure 11- 1. CE Block Diagram

### 11.1.3. Operations and Functional Descriptions

#### 11.1.3.1. Task Descriptor of Hash Algorithms and RBG Algorithms

The task descriptor is data written by software to a contiguous space in memory. The data describes the various properties of a task, such as algorithm type, mode, subcommand, key address, data source address, the data size read from data source, abstract destination address, the written destination data size, and the information of other tasks. First, we configures the task descriptor by software; then we operates the registers of CE to start this task. After the task starts, CE will read task descriptor based on the address of the task descriptor configured in register, and perform the task one time based on the described properties.

In applications, the “NEXT TASK ADDR” field can be configured as the starting address of the next task descriptor, to concatenate multi task descriptors into a task chain. After starting the first task, CE will perform every task in order until the “NEXT TASK ADDR” field is invalid (that is 0).

The HASH/RBG algorithms and Symmetrical/Asymmetrical algorithms use the different descriptor structure, separately.



**Figure 11- 2. Task Chaining of Hash Algorithms and Random Bit Generator Algorithms**

The detail structures are as follows.

| No. | Descriptor | Name | Width | Description                    |
|-----|------------|------|-------|--------------------------------|
| 0   | CTRL       | CHN  | [1:0] | Channel ID                     |
|     |            | IVE  | [8]   | IV mode enable, active high    |
|     |            | LPKG | [12]  | Last package flag, active high |

|       |       |          |         |                                                                                                                                                                                                                                                                                                                                                  |
|-------|-------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       | DLAV     | [13]    | <p>Data length valid<br/>For last package, the bit needs be configured. For non last package, the bit needs not be configured.<br/>(Please configure it as 0 in PRNG/TRNG/DRBG .)</p> <p>1: DLA means the WORD address where data total length (by bits) is saved.<br/>0: DLA means the value of message total length (by bits).</p>             |
|       |       | IE       | [16]    | Interrupt enable for current task, active high                                                                                                                                                                                                                                                                                                   |
| 1     | CMD   | HASH SEL | [3:0]   | <p>Hash algorithms select<br/>0: MD5<br/>1: SHA1<br/>2: SHA224<br/>3: SHA256<br/>4: SHA384<br/>5: SHA512<br/>6: SM3<br/>Other: Reserved</p>                                                                                                                                                                                                      |
|       |       | HME      | [4]     | HMAC mode enable, active high                                                                                                                                                                                                                                                                                                                    |
|       |       | RGB SEL  | [11:8]  | <p>RGB algorithms select<br/>0: No RGB use<br/>1: PRNG<br/>2: TRNG<br/>3: DRBG<br/>Other: Reserved</p>                                                                                                                                                                                                                                           |
|       |       | SUB CMD  | [31:16] | Sub-command in a specific algorithms                                                                                                                                                                                                                                                                                                             |
| 2     | DLA   | DLA      | [31:0]  | <p>Data length OR its address.<br/>For last package, the field needs be configured. For non last package, the field needs not be configured.<br/>(Not used in PRNG/TRNG/DRBG.)</p> <p>When DLAV=1, here is the WORD address where data total length (by bits) is saved.<br/>When DLAV=0, here is the value of message total length (by bits)</p> |
| 3     | KA    | KA       | [31:0]  | <p>KEY address<br/>The WORD address where HMAC KEY or PRNG KEY is saved.</p>                                                                                                                                                                                                                                                                     |
| 4     | IVA   | IVA      | [31:0]  | <p>IV address<br/>The WORD address where IV is saved.</p>                                                                                                                                                                                                                                                                                        |
| 5+2*x | SRCAx | SRCAx    | [31:0]  | <p>Source data address x<br/>The WORD address where source data is saved.</p>                                                                                                                                                                                                                                                                    |
| 6+2*x | SRCSx | SRCSx    | [31:2]  | <p>Source data address x<br/>The length (by words) of source datax.<br/>If the length is less than 1 word, it will calculate as 1 word.<br/>except the last word of total HASH message can be non-integer word, others must be integer word.</p>                                                                                                 |

|        |          |          |        |                                                                                                                                                                                     |
|--------|----------|----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21+2*x | DSTAx    | DSTAx    | [31:0] | Output data address x<br>The WORD address where output data is saved.                                                                                                               |
| 22+2*x | DSTSx    | DSTSx    | [31:2] | Source data address x<br>The Length (by words) of source data.                                                                                                                      |
| 37     | NTA      | NTA      | [31:0] | Next task address<br>The WORD address where the descriptor of the next task in a task-chain is saved. If this is the only task or the last task of a task-chain, NTA must be 30'h0. |
| 38     | Reserved | Reserved | /      | /                                                                                                                                                                                   |
| 39     | Reserved | Reserved | /      | /                                                                                                                                                                                   |
| 40     | Reserved | Reserved | /      | /                                                                                                                                                                                   |

### 11.1.3.2. Specific in DRBG Base on HASH/RBG Task Descriptor

#### 11.1.3.2.1. Sub-Cmd in DRBG

| Name               | Width | Description                                                                       |
|--------------------|-------|-----------------------------------------------------------------------------------|
| CMD                | [2:0] | Process Command<br>0: Instantiate<br>1: Reseed<br>2: Generate<br>3: Uninstantiate |
| /                  | [3]   | /                                                                                 |
| Internal States ID | [6:4] | Internal States ID: 0-7                                                           |
| /                  | [7]   | /                                                                                 |
| PRR                | [12]  | Prediction Resistance Request. Active HIGH.                                       |

#### 11.1.3.2.2. SRCAx/SRCSx in DRBG

| Name in Basic HASH | Width  | Description In DRBG                                          |
|--------------------|--------|--------------------------------------------------------------|
| SRCA0              | [31:0] | Entropy Input Address                                        |
| SRCS0              | [31:0] | Entropy Input Length (By Bytes), should be multiple of 4     |
| SRCA1              | [31:0] | Nonce Address                                                |
| SRCS1              | [31:0] | Nonce Length (By Bytes), should be multiple of 4             |
| SRCA2              | [31:0] | Personalization Address                                      |
| SRCS2              | [31:0] | Personalization Length (By Bytes) , should be multiple of 4  |
| SRCA3              | [31:0] | Additional Input Address                                     |
| SRCS3              | [31:0] | Additional Input Length (By Bytes) , should be multiple of 4 |

### 11.1.3.3. Task Descriptor of Symmetrical Algorithms and Asymmetrical Algorithms

Software make request through task descriptor, providing algorithm type, mode, key address, source/destination address and size, etc. The task descriptor is as follows.



Figure 11- 3. Task Chaining of Symmetrical Algorithms and Asymmetrical Algorithms

Task chaining id supports 0~3.

The key addr field is address for the key of each algorithm, also for extension feature micro codes address. **Must be word address.**

The iv addr field is tweak value address for XTS.

The ctr addr is address for the IV of next block. **Must be word address.**

The src/dst sgX adr field indicates 32-bit address for source and destination data. **Must be word address.**

The src/dst sgX size field indicates size for each sg respectively.

The next task field should be set to 0 when no next task, else set to the descriptor of next task.

#### 11.1.3.3.1. Task Descriptor Queue Common Control

| Bit   | Read/Write | Default/Hex | Description                                                                                 |
|-------|------------|-------------|---------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | Interrupt enable for current task<br>0: disable interrupt<br>1: enable interrupt            |
| 30:25 | /          | /           | /                                                                                           |
|       |            |             | cbc_mac_len<br>The field is used as the outcome bit length of CBC-MAC when in CBC-MAC mode. |
| 24:17 | R/W        | 0           | The field also is used as the tag_len of GCM/OCB mode.                                      |

|      |     |     |                                                                                                                                                                       |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16:9 | /   | /   | /                                                                                                                                                                     |
| 8    | R/W | 0x0 | OP DIR<br>Algorithm Operation Direction<br>0: Encryption<br>1: Decryption                                                                                             |
| 7    | /   | /   | /                                                                                                                                                                     |
| 6:0  | R/W | 0x0 | Algorithm Type<br>0x0: AES<br>0x1: DES<br>0x2: Triple DES (3DES)<br>0x3 : SM4<br>....<br>0x20: RSA<br>0x21: ECC<br>0x22: SM2<br>...<br>0x30: RAES<br>Others: Reserved |

#### 11.1.3.3.2. Task Descriptor Queue Symmetric Control

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
|-------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | /          | /           | /                                                                                                                                                                                                                                      |
| 26    | R/W        | 0x0         | no_modk<br>0: have module key derivation function<br>1: no module key derivation function                                                                                                                                              |
| 25:24 | /          | /           | /                                                                                                                                                                                                                                      |
| 23:20 | R/W        | 0x0         | KEY_SELECT<br><br>key select for AES/SM4/3DES ( 3DES only configured as 0,or 8-15 )<br><br>0: Select input CE_KEYx (Normal Mode)<br>1: Select {SSK}<br>2: Select {HUK}<br>3-7: Reserved<br>8-15: Select internal Key n (n from 0 to 7) |
| 19:18 | R/W        | 0x0         | CFB_WIDTH<br>For AES-CFB width<br>00: CFB1<br>01: CFB8<br>10: CFB64<br>11: CFB128                                                                                                                                                      |
| 17    | /          | /           | /                                                                                                                                                                                                                                      |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16    | R/W | 0x0 | AES CTS last package flag<br>When setting to '1', it means this is the last package for CTS mode(the size of the last package >128bit).<br>The bit also is used as the gcm_last/ocb_last for GCM/OCB mode.                                                                                                                                                                                                                                                                                                                                               |
| 15:14 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13    | R/W | 0x0 | xts_last<br>0: not last block for XTS<br>1: last block for XTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12    | R/W | 0x0 | xts_first<br>0: not first block for XTS<br>1: first block for XTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11:8  | R/W | 0x0 | Operation Mode for Symmetric<br>AES/DES/3DES/RAES Modes<br>DES/3DES only supports ECB/CBC/CTR.<br>RAES only supports ECB/CBC/XTS.<br>0000: Electronic Code Book (ECB) mode<br>0001: Cipher Block Chaining (CBC) mode<br>0010: Counter (CTR) mode<br>0011: CipherText Stealing (CTS) mode<br>0100: Output feedback (OFB) mode<br>0101: Cipher feedback (CFB) mode<br>0110: CBC-MAC mode<br>0111: OCB mode<br>1000: GCM mode<br>1001: XTS mode<br>Others: Reserved                                                                                         |
| 7:6   | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5:4   | R/W | 0x0 | gcm_iv_mode[1:0]<br>gcm_iv_mode[0]: value 1 show the last req for iv calculate<br>gcm_iv_mode[1]:<br>0 :no GHASH calculate mode<br>1: GHASH calculate mode<br><br>gcm_iv_mode[1:0]:<br>00: IDLE state ,this calculate do not have the process from iv to J0<br>01: by iv padding generating J0. On the mode, iv padding is 96 bits, so iv_length will be 96 bits<br>10: by GHASH calculate for iv generating J0, and this is not the last req for iv calculate<br>11: by GHASH calculate for iv generating J0, and this is the last req for iv calculate |
| 3:2   | R/W | 0x0 | CTR WIDTH<br>Counter width for CTR mode<br>00: 16-bit Counter<br>01: 32-bit Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

|     |     |     |                                                                           |
|-----|-----|-----|---------------------------------------------------------------------------|
|     |     |     | 10: 64-bit Counter<br>11: 128-bit Counter                                 |
| 1:0 | R/W | 0x0 | AES KEY SIZE<br>00: 128-bit<br>01: 192-bit<br>10: 256-bit<br>11: Reserved |

#### 11.1.3.3.3. Task Descriptor Queue Asymmetric Control

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 20:16 | R/W        | 0x0         | <p>PKC algorithm mode<br/>                     For modular computation:<br/>                     00000: modular exponent(RSA)<br/>                     00001: modular add<br/>                     00010: modular minus<br/>                     00011: modular multiplication<br/>                     others: reserved</p> <p>For ECC:<br/>                     00000: point add<br/>                     00001: point double<br/>                     00010: point multiplication<br/>                     00011: point verification<br/>                     00100: encryption<br/>                     00101: decryption<br/>                     00110: sign<br/>                     00111: sign verify<br/>                     others: reserved</p> <p>For SM2 :</p> <p>00000: encryption<br/>                     00001: decryption<br/>                     00010: sign<br/>                     00011: sign verify<br/>                     00100: key exchange</p> |
| 15:8  | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:0   | R/W        | 0x0         | Asymmetric algorithms operation width field<br>It indicates how much width this request apply, as words.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 11.1.3.4. Security Operations

CE has two sets of complete registers, the base address of one register is CE\_NS, is called non-secure world; the base address of the other register is CS\_S, is called secure world. The configurations of two registers are independent each other. The task started by configuring the non-secure world register is called non-secure task; otherwise, called secure task. The difference between secure world and non-secure world has mainly two aspects.

- Non-secure CPU only can access the registers of non-secure world; secure CPU can access the registers of non-secure world and the registers of secure world;
- Non-secure task can not access any secure domain in system, such as KEYSRAM and SID. But secure task can.

For example, if the EK stored in KEYSRAM needs to do a MD5 operation, the task requires CE to read the EK of KEYSRAM during execution, so it can only access secure-world registers by secure CPU to configure and start the task.

#### 11.1.3.5. Task Parallel

Algorithms are divided into 4 types: symmetric, HASH/RBG, asymmetric, and RAES. These four algorithms can run in parallel. Among these 4 types, the task request and complete time are not sure. If one type uses the outcome of another type, software should make sure to start one type after another type is finished.

Each type has a task queue with 8 elements for requests. Tasks in each queue are handled in sequence. If software makes several requests with the same type, these tasks will be executed in request sequence. If software makes several requests with different types, these tasks will be executed in parallel.

CE supports 4 virtual channels with ID 0-3 in each world. Because parallel tasks would finish out of order, software should make different type request with different channel id, which results in generating different interrupt status bit.

#### 11.1.3.6. PKC Microcode

PKC module supports RSA, ECC, SM2 algorithms in the form of microcode. It implements basic modular add, minus, multiplication, point add, point double, and logic computing, etc. Complete RSA/ECC/SM2 encryption, decryption, sign, verify are implemented with these microcode.

Asymmetric algorithms RSA/ECC/SM2 are implemented as microcode in PKC module. The encryption, decryption, sign, verify operations of asymmetric algorithms are composed with certain fixed microcode with hardware.

#### 11.1.3.7. PKC Configuration

Before starting PKC, task description must be configured. Parameters to PKC are assigned to source sg, outcome is put to destination sg.

For RSA, parameters should be at the order of key, modulus, plaintext.

For ECC point add  $P_2 = P_0 + P_1$ , parameters should be at the order of p, P0x, P0y, P1x, P1y. Output is at the order of P2x, P2y.

For ECC point double  $P_2 = 2 * P_0$ , parameters should be at the order of p, a, P0x, P0y. Output is at the order of P2x, P2y.

For ECC point multiplication  $P2 = k * P0$ , parameters should be at the order of  $p, k, a, P0x, P0y$ . Output is at the order of  $P2x, P2y$ .

For ECC point verification, parameters should be at the order of  $p, a, P0x, P0y, b$ . Output is 1 or 0.

For ECC encryption, parameters should be at the order of random  $k, p, a, Gx, Gy, Qx, Qy, m$ . Output is at the order of  $Rx, Ry, c$ .

For ECC decryption, parameters should be at the order of random  $k, p, a, Rx, Ry, c$ . Output is  $m$ .

For ECC signature, parameters should be at the order of random  $k, p, a, Gx, Gy, n, d, e$ . Output is at the order of  $r, s$ .

For ECC signature verification, parameters should be at the order of  $n, s, e, r, p, a, Gx, Gy, Qx, Qy, n, r$ . Output is 1 or 0.

#### 11.1.3.8. Error Check

After CE reads the task descriptor, CE can monitor error during algorithm operation. When the error is monitored, CE will do the following operations:

The task will pause immediately

Generates interrupt

The corresponding channel of the task status register is Fail

The corresponding channel bit of error status register can be read error number

The error number has the following types.

| Code | Name                                                               | Description                                                                                                                                                                                                                                                                                                  | Algorithms Type |
|------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0x01 | algorithm not support                                              | The algorithm type is not supported.                                                                                                                                                                                                                                                                         | All             |
| 0x11 | KEYSRAM access error                                               | In AES decryption task, RSSK is used as plaintext, the DST address is not in KEYSRAM space.                                                                                                                                                                                                                  | AES decryption  |
| 0x31 | data length error                                                  | Input size or output size configuration size error.                                                                                                                                                                                                                                                          | All             |
| 0x42 | DRBG internal state invalid                                        | The internal status ID is invalid in the task. For example:<br>1. When executing the instantiate, an internal status that has been instantiated but not destroyed is used.<br>2. When executing the reseed/generate/uninstantiate, an internal status that has not been used and has been destroyed is used. | DRBG            |
| 0x44 | DRBG entropy or nonce missing                                      | The size of entropy or nonce required for the task is 0.                                                                                                                                                                                                                                                     | DRBG            |
| 0x46 | DRBG does not support prediction resistance in current instantiate | The task requests prediction resistance, but the used internal status is instantiate, prediction resistance enable has not been signed.                                                                                                                                                                      | DRBG            |

#### 11.1.3.9. Clock Requirement

| Clock Name | Description   | Requirement      |
|------------|---------------|------------------|
| ahb_clk    | AHB bus clock | 24 MHz ~ 200 MHz |
| m_clk      | MBUS clock    | 24 MHz ~ 400 MHz |

|         |                   |                  |
|---------|-------------------|------------------|
| ce_clk  | CE work clock     | 24 MHz ~ 300 MHz |
| osl_clk | TRNG sample clock | <3 MHz           |

#### 11.1.4. Register List

| Module Name | Base Address |
|-------------|--------------|
| CE_NS       | 0x01904000   |
| CE_S        | 0x01904800   |

| Register Name | Offset | Description                                                         |
|---------------|--------|---------------------------------------------------------------------|
| CE_TDA        | 0x0000 | Task Descriptor Address                                             |
| CE_ICR        | 0x0008 | Interrupt Control Register                                          |
| CE_ISR        | 0x000C | Interrupt Status Register                                           |
| CE_TLR        | 0x0010 | Task Load Register                                                  |
| CE_TSR        | 0x0014 | Task Status Register                                                |
| CE_ESR        | 0x0018 | Error Status Register                                               |
| CE_DRL        | 0x001C | DRBG Request Limit Register                                         |
| CE_SCSA       | 0x0024 | Symmetric Algorithm DMA Current Source Address(For CE_S only)       |
| CE_SCDA       | 0x0028 | Symmetric Algorithm DMA Current Destination Address(For CE_S only)  |
| CE_HCSA       | 0x0034 | HASH Algorithm DMA Current Source Address(For CE_S only)            |
| CE_HCDA       | 0x0038 | HASH Algorithm DMA Current Destination Address(For CE_S only)       |
| CE_ACSA       | 0x0044 | Asymmetric Algorithm DMA Current Source Address(For CE_S only)      |
| CE_ACDA       | 0x0048 | Asymmetric Algorithm DMA Current Destination Address(For CE_S only) |
| CE_XCSA       | 0x0054 | XTS Algorithm DMA Current Source Address(For CE_S only)             |
| CE_XCDA       | 0x0058 | XTS Algorithm DMA Current Destination Address(For CE_S only)        |

#### 11.1.5. Register Description

##### 11.1.5.1. 0x0000 CE Task Descriptor Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CE_TDA                            |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:0           | R/W        | 0x0         | Task Descriptor Address<br>Must be word address. |

**11.1.5.2. 0x0008 CE Interrupt Control Register(Default Value: 0x0000\_0000)**

| Offset: 0x0008 |            |             | Register Name: CE_ICR                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:4           | /          | /           | /                                                                              |
| 3              | R/W        | 0x0         | Channel 3 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable |
| 2              | R/W        | 0x0         | Channel 2 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable |
| 1              | R/W        | 0x0         | Channel 1 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable |
| 0              | R/W        | 0x0         | Channel 0 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable |

**11.1.5.3. 0x000C CE Interrupt Status Register(Default Value: 0x0000\_0000)**

| Offset: 0x000C |            |             | Register Name: CE_ISR                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                        |
| 7:6            | R/W1C      | 0x0         | Channel 3 Task Status<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 5:4            | R/W1C      | 0x0         | Channel 2 Task Status<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 3:2            | R/W1C      | 0x0         | Channel 1 Task Status<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 1:0            | R/W1C      | 0x0         | Channel 0 Task Status<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |

#### 11.1.5.4. 0x0010 CE Task Load Register(Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: CE_TLR                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                            |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                      |
| 3              | R/W        | 0x0         | <p>Task Load for Channel RAES Type</p> <p>Read as 1: CE is busy to load another task, or the task queue is full. Writing this bit is not allowed now.</p> <p>Read as 0: CE is ready to load another task</p> <p>Write 1: Load task and start to run.</p> <p>Write 0: No effect</p>     |
| 2              | R/W        | 0x0         | <p>Task Load for Channel ASYM Type</p> <p>Read as 1: CE is busy to load another task, or the task queue is full. Writing this bit is not allowed now.</p> <p>Read as 0: CE is ready to load another task</p> <p>Write 1: Load task and start to run.</p> <p>Write 0: No effect</p>     |
| 1              | R/W        | 0x0         | <p>Task Load for Channel HASH/RBG type</p> <p>Read as 1: CE is busy to load another task, or the task queue is full. Writing this bit is not allowed now.</p> <p>Read as 0: CE is ready to load another task</p> <p>Write 1: Load task and start to run.</p> <p>Write 0: No effect</p> |
| 0              | R/W        | 0x0         | <p>Task Load for Channel SYMM type</p> <p>Read as 1: CE is busy to load another task, or the task queue is full. Writing this bit is not allowed now.</p> <p>Read as 0: CE is ready to load another task</p> <p>Write 1: Load task and start to run.</p> <p>Write 0: No effect</p>     |

#### 11.1.5.5. 0x0014 CE Task Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: CE TSRMLS                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31:8           | /          | /           | /                                                                                                                                                |
| 7:6            | R          | 0x0         | <p>indicate which channel is run for XTS</p> <p>00: task channel0</p> <p>01: task channel1</p> <p>10: task channel2</p> <p>11: task channel3</p> |
| 5:4            | R          | 0x0         | <p>indicate which channel is run for asymmetric</p> <p>00: task channel0</p> <p>01: task channel1</p> <p>10: task channel2</p>                   |

|     |   |     |                                                                                                                                 |
|-----|---|-----|---------------------------------------------------------------------------------------------------------------------------------|
|     |   |     | 11: task channel3                                                                                                               |
| 3:2 | R | 0x0 | indicate which channel in run for digest<br>00: task channel0<br>01: task channel1<br>10: task channel2<br>11: task channel3    |
| 1:0 | R | 0x0 | indicate which channel in run for symmetric<br>00: task channel0<br>01: task channel1<br>10: task channel2<br>11: task channel3 |

#### 11.1.5.6. 0x0018 CE Error Status Register(Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: CE_ESR                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                       |
| 31:24          | R          | 0x0         | Error code for task channel 3<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x31: data length error<br>0x42: DRBG internal state invalid<br>0x44: DRBG Entropy or Nonce missing<br>0x46: DRBG do not support Prediction Resistance in current Instantiate<br>others: reserved |
| 23:16          | R          | 0x0         | Error code for task channel 2<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x31: data length error<br>0x42: DRBG internal state invalid<br>0x44: DRBG Entropy or Nonce missing<br>0x46: DRBG do not support Prediction Resistance in current Instantiate<br>others: reserved |
| 15:8           | R          | 0x0         | Error code for task channel 1<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x31: data length error<br>0x42: DRBG internal state invalid<br>0x44: DRBG Entropy or Nonce missing<br>0x46: DRBG do not support Prediction Resistance in current Instantiate<br>others: reserved |
| 7:0            | R          | 0x0         | Error code for task channel 0                                                                                                                                                                                                                                                                                     |

|  |  |  |                                                                                                                                                                                                                                                                                  |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x31: data length error<br>0x42: DRBG internal state invalid<br>0x44: DRBG Entropy or Nonce missing<br>0x46: DRBG do not support Prediction Resistance in current Instantiate<br>others: reserved |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 11.1.5.7. 0x001C CE DRBG Request Limit Register (Default: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: CE_DRL                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31:0           | R/W        | 0x0         | The register remains unchanged before all DRBG task is completed. Only when there are no tasks to be completed, the register can be configured. |

#### 11.1.5.8. 0x0024 CE Symmetric Current Source Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CE_SCSA                                  |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:0           | R          | 0x0         | Symmetric algorithm current source address read by DMA. |

#### 11.1.5.9. 0x0028 CE Symmetric Current Destination Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CE_SCDA                                          |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:0           | R          | 0x0         | Symmetric algorithm current destination address written by DMA. |

#### 11.1.5.10. 0x0034 CE HASH Current Source Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: CE_HCSA                             |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:0           | R          | 0x0         | HASH algorithm current source address read by DMA. |

#### 11.1.5.11. 0x0038 CE HASH Current Destination Address Register(Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: CE_HCDA                                     |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:0           | R          | 0x0         | HASH algorithm current destination address written by DMA. |

**11.1.5.12. 0x0044 CE Asymmetric Current Source Address Register(Default Value: 0x0000\_0000)**

| Offset: 0x0044 |            |             | Register Name: CE_ACSC                                   |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:0           | R          | 0x0         | Asymmetric algorithm current source address read by DMA. |

**11.1.5.13. 0x0048 CE Asymmetric Current Destination Address Register(Default Value: 0x0000\_0000)**

| Offset: 0x0048 |            |             | Register Name: CE_ACDA                                           |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:0           | R          | 0x0         | Asymmetric algorithm current destination address written by DMA. |

**11.1.5.14. 0x0054 CE XTS Current Source Address Register(Default Value: 0x0000\_0000)**

| Offset: 0x0054 |            |             | Register Name: CE_XCSA                            |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:0           | R          | 0x0         | XTS algorithm current source address read by DMA. |

**11.1.5.15. 0x0058 CE XTS Current Destination Address Register(Default Value: 0x0000\_0000)**

| Offset: 0x0058 |            |             | Register Name: CE_XCDA                                    |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:0           | R          | 0x0         | XTS algorithm current destination address written by DMA. |

## 11.2. Security ID

The Security ID(SID) is 2 Kbits electrical efuse for saving key, which includes chip ID, thermal sensor, and security key, etc.

The SID module has the following features:

- The module register is non-secure forever, and the efuse has secure zone and non-secure zone
- A fuse only can program one time