



Hi3796M V100 Intelligent Network Terminal Media Processor

## Data Sheet

Issue 00B03

Date 2015-01-07

**Copyright © HiSilicon Technologies Co., Ltd. 2015. All rights reserved.**

No part of this document may be reproduced or transmitted in any form or by any means without prior written consent of HiSilicon Technologies Co., Ltd.

**Trademarks and Permissions**

 **HISILICON**, and other HiSilicon icons are trademarks of HiSilicon Technologies Co., Ltd.

All other trademarks and trade names mentioned in this document are the property of their respective holders.

**Notice**

The purchased products, services and features are stipulated by the contract made between HiSilicon and the customer. All or part of the products, services and features described in this document may not be within the purchase scope or the usage scope. Unless otherwise specified in the contract, all statements, information, and recommendations in this document are provided "AS IS" without warranties, guarantees or representations of any kind, either express or implied.

The information in this document is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents, but all statements, information, and recommendations in this document do not constitute a warranty of any kind, express or implied.

**HiSilicon Technologies Co., Ltd.**

Address:   Huawei Industrial Base  
              Bantian, Longgang  
              Shenzhen 518129  
              People's Republic of China

Website:   <http://www.hisilicon.com>

Email:       [support@hisilicon.com](mailto:support@hisilicon.com)



# About This Document

## Purpose

This document describes the functions of the intelligent network terminal media processor Hi3796M V100. It also describes how to configure the chip in typical application scenarios.

## Related Version

The following table lists the product version related to this document.

| Product | Version |
|---------|---------|
| Hi3796M | V1XX    |

## Intended Audience

This document is intended for:

- Software development engineers
- Technical support personnel

## Symbol Conventions

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

| Symbol         | Description                                                                                               |
|----------------|-----------------------------------------------------------------------------------------------------------|
| <b>DANGER</b>  | Alerts you to a high risk hazard that could, if not avoided, result in serious injury or death.           |
| <b>WARNING</b> | Alerts you to a medium or low risk hazard that could, if not avoided, result in moderate or minor injury. |



| Symbol         | Description                                                                                                                                                             |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CAUTION</b> | Alerts you to a potentially hazardous situation that could, if not avoided, result in equipment damage, data loss, performance deterioration, or unanticipated results. |
| <b>TIP</b>     | Provides a tip that may help you solve a problem or save time.                                                                                                          |
| <b>NOTE</b>    | Provides additional information to emphasize or supplement important points in the main text.                                                                           |

## Register Attributes

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

| Symbol | Description                        | Symbol | Description                                                                                                                |
|--------|------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------|
| RO     | The register is read-only.         | RW     | The register is read/write.                                                                                                |
| RC     | The register is cleared on a read. | WC     | The register can be read.<br>The register is cleared when 1 is written.<br>The register keeps unchanged when 0 is written. |

## Reset Value Conventions

In the register definition tables:

- If the reset value (for the Reset row) of a bit is "?", the reset value is undefined.
- If the reset values of one or multiple bits are "?", the total reset value of a register is undefined and is marked as "-".

## Numerical System

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

| Type                                     | Symbol | Value         |
|------------------------------------------|--------|---------------|
| Data capacity (such as the RAM capacity) | K      | 1024          |
|                                          | M      | 1,048,576     |
|                                          | G      | 1,073,741,824 |
| Frequency, data rate                     | k      | 1000          |



| Type | Symbol | Value         |
|------|--------|---------------|
|      | M      | 1,000,000     |
|      | G      | 1,000,000,000 |

The expressions of addresses and data are described as follows.

| Symbol | Example              | Description                                                                                                            |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------|
| 0x     | 0xFE04, 0x18         | Address or data in hexadecimal                                                                                         |
| 0b     | 0b000, 0b00 00000000 | Data or sequence in binary (register description is excluded.)                                                         |
| X      | 00X, 1XX             | In data expression, X indicates 0 or 1. For example, 00X indicates 000 or 001 and 1XX indicates 100, 101, 110, or 111. |

## Others

Frequencies in this document all comply with the SDH standard. The shortened frequency names and the corresponding nominal frequencies are as follows.

| Shortened Frequency Name | Nominal Frequency |
|--------------------------|-------------------|
| 19 M                     | 19.44 MHz         |
| 38 M                     | 38.88 MHz         |
| 77 M                     | 77.76 MHz         |
| 622 M                    | 622.08 MHz        |

## Change History

Changes between document issues are cumulative. Therefore, the latest document issue contains all changes made in previous issues.

### Issue 00B03 (2015-01-07)

This issue is the third draft release. Which incorporates the following changes:

Chapter 1, chapter 8, and chapter 11 are modified.

### Issue 00B02 (2014-12-16)

This issue is the second draft release. Which incorporates the following changes:



Chapter 3 is modified.

## Issue 00B01 (2014-11-17)

This issue is the first draft release.



# Contents

|                                            |            |
|--------------------------------------------|------------|
| <b>1 Overview.....</b>                     | <b>1-1</b> |
| 1.1 Application Scenarios.....             | 1-1        |
| 1.2 Architecture .....                     | 1-2        |
| 1.2.1 Master Processor.....                | 1-2        |
| 1.2.2 3D Engine .....                      | 1-3        |
| 1.2.3 Security Features.....               | 1-3        |
| 1.2.4 Memory Interfaces.....               | 1-3        |
| 1.2.5 Data Stream Interfaces .....         | 1-4        |
| 1.2.6 Video CODEC HiVXE .....              | 1-4        |
| 1.2.7 Graphics and Display Processing..... | 1-5        |
| 1.2.8 Audio/Video Interfaces .....         | 1-5        |
| 1.2.9 Peripheral Interfaces .....          | 1-6        |
| 1.2.10 Boot Modes.....                     | 1-7        |
| 1.2.11 Low-Power Control.....              | 1-7        |
| 1.3 Address Space Mapping.....             | 1-7        |



## Figures

**Figure 1-1 Application block diagram of Hi3796M V100 ..... 1-2**



## Tables

**Table 1-1 Address space mapping .....** ..... 1-8



# 1 Overview

## 1.1 Application Scenarios

Hi3796M V100 is a cost-effective 4K/H.265 STB chip solution. It brings the best user experience in the industry in terms of stream compatibility, smoothness and picture quality of video playback, and STB performance. With an integrated high-performance quad-core processor and embedded NEON, Hi3796M V100 meets differentiated service requirements. It also supports Dolby and DTS audio processing. To meet the growing requirements on multimedia playback, video communication, and multi-screen transcoding, Hi3796M V100 supports HD video decoding in various formats (including H.265, H.264, AVS+, MPEG2, MPEG4, VC-1, VP6, and VP8) and high-performance H.264 encoding. Hi3796M V100 provides a smooth man-machine interface and rich gaming experience with a high-performance multi-core 2D/3D acceleration engine. It also enables flexible connection schemes with one Ethernet port, three USB 2.0 ports, one USB 3.0 port, and more peripheral interfaces.

[Figure 1-1](#) shows the typical application block diagram of Hi3798M V100.



Figure 1-1 Application block diagram of Hi3796M V100



## 1.2 Architecture

Hi3796M V100 has the following features:

- Master processor
- 3D engine
- Security processing
- Memory interfaces
- Data stream interfaces
- Video CODEC
- Graphics and display processing
- Audio/Video interfaces
- Peripheral interfaces and boot modes
- Low-power control processor

### 1.2.1 Master Processor

Hi3796M V100 integrates an ARM Cortex A7 quad-core processor as the master CPU to implement system functions and some audio and video processing tasks. This processor has the following features:



- Maximum frequency of 1.5 GHz
- Independent 32 KB I-cache and 32 KB D-cache, 512 KB shared L2 cache
- Integrated NEON
- Dynamic power consumption reduction such as dynamic voltage and frequency scaling (DVFS) and adaptive voltage scaling (AVS)

## 1.2.2 3D Engine

Hi3796M V100 integrates the high-performance quad-core Mali GPU to process 3D graphics and videos.

- OpenGL ES 2.0/1.1/1.0
- OpenVG 1.1
- Embedded-system graphics library (EGL)
- 1080p30 UI processing capability
- 1080p30 gaming applications

## 1.2.3 Security Features

Hi3796M V100 has the following advanced security features:

- Secure boot
- Content protection and encryption and decryption hardware engines compliant with the advanced encryption standard (AES) and triple advanced encryption standard (3DES)
- Joint Test Action Group (JTAG) protection
- One time programmable (OTP)

## 1.2.4 Memory Interfaces

Hi3796M V100 provides various memory interfaces, including controllers for the DDR SDRAM, NAND flash, and secure digital input/output (SDIO)/multimedia card (MMC).

### DDRC

The DDR3/3L SDRAM controller (DDRC) controls the access to the DDR3/3L SDRAM. It supports the following features:

- Maximum 2 GB capacity
- 16-bit or 32-bit memory
- Maximum 800 MHz frequency
- Standby power-down

### NANDC

The NAND flash controller (NANDC) controls the access to the asynchronous NAND flash. It supports the following features:

- SLC/MLC flash memory
- Asynchronous NAND flash
- One CS and 8-bit width
- 8-/16-/24-/28-/40-/64-bit error-correcting code (ECC)



- Components with the 2/4/8/16 KB page size
- Randomization for components with the 8/16 KB page size
- Maximum 512 GB capacity

## MMC/SD/SDIO Controller

Hi3796M V100 integrates two high-speed large-capacity SDIO 3.0/MMC 4.5 controllers to control the access to the MMC/SD card. In addition, extended peripherals such as Bluetooth and Wi-Fi devices can be connected over the SDIO interface.

One controller supports the 1-/4-bit mode. The other supports the 1-/4-/8-bit mode, and the interface is multiplexed with the NAND flash interface.

## 1.2.5 Data Stream Interfaces

Hi3796M V100 provides the data stream interfaces including the Ethernet ports and transport stream interface (TSI).

### Ethernet Ports

Hi3796M V100 integrates a dual-port Ethernet switching controller, providing two fast Ethernet MAC ports to exchange data with the CPU.

- Working at 10/100 Mbit/s, in half-duplex or full-duplex mode
- One integrated 10/100 Mbit/s PHY and support for energy-efficient Ethernet (EEE)
- Configurable destination MAC address filtering table, which filters the input frames of the Ethernet port
- Traffic control of the CPU interface, protecting the CPU against heavy traffic

### TSI

Hi3796M V100 integrates the TSI controller.

- Parsing and demultiplexing of MPEG2 TSs (complying with the ISO 13818-1 GB 17975-1 system layer)
- At most two external DVB serial inputs
- Maximum 96 hardware PID channels

## 1.2.6 Video CODEC HiVXE

Hi3796M V100 integrates the HD video and graphics CODEC that supports various protocols (H.265/H.264/AVS+/MVC/VC-1/MPEG2/MPEG4/AVS/VP6/VP8/JPEG/PNG), providing powerful video and graphics encoding and decoding capabilities.

- H.265 MP@L5.0
- H.264 BP/MP/HP@L5.1 and MVC decoding
- AVS baseline@L6.0 and AVS+ decoding
- MPEG1 decoding
- MPEG2 MP@HL decoding
- MPEG4 SP@L0–3 and ASP@L0–5 decoding
- MPEG4 short header format (H.263 baseline) decoding



- VC-1 AP@L0–3 decoding
- VP6/VP8 decoding
- Maximum decoding capability of 4K x 2K@30 fps, 1080p@60 fps, or 2x1080p@30 fps
- Full HD JPEG baseline decoding, up to 64 megapixels
- MJPEG baseline decoding, maximum decoding capability of 1080p@40 fps
- PNG decoding, maximum 64 megapixels
- H.264 BP/MP/HP@L4.2 encoding, maximum encoding capability of 1080p@30 fps
- JPEG baseline encoding, maximum encoding capability of 1080p@30 fps
- Variable bit rate (VBR) or constant bit rate (CBR) mode for video encoding

## 1.2.7 Graphics and Display Processing

Hi3796M V100 integrates the dedicated two dimensional engine (TDE), dedicated hardware composer engine, and dedicated display processing engine.

- Hardware overlaying of multi-channel graphics and video inputs
- Three-layer on-screen display (OSD) and four video layers
- Maximum 4K x 2K image output
- Mosaic and multi-region display
- Mirroring
- 16-bit or 32-bit color depth
- Image or video rotation
- LetterBox and PanScan
- 3D video processing and display
- Multi-order vertical and horizontal scaling of videos and graphics; free scaling
- Low-delay display
- Enhanced full-hardware TDE
- Full-hardware anti-aliasing and anti-flicker
- Color space conversion (CSC) with configurable coefficients
- Image enhancement and denoising
- Deinterlacing
- Sharpening
- Chrominance, luminance, contrast, and saturation adjustment
- Db/Dr processing for graphics and videos

## 1.2.8 Audio/Video Interfaces

Hi3796M V100 integrates various audio/video input/output interfaces, providing rich audio/video input/output capabilities.

### Video Input/Output Interfaces

- One 1920 x 1080p@60 fps output and one SD output from the same source or different sources
- One HDMI 1.4a TX output, maximum 4K x 2K resolution



- One digital-to-analog converter (DAC), supporting one composite video broadcast signal (CVBS) output
- Rovi and vertical blanking interval (VBI) video output

## Audio Input/Output Interfaces

- Sony/Philips digital interface format (SPDIF) audio output interface
- One embedded DAC, which supports audio-left and audio-right channels (output interface of the RCA type, low impedance, and imbalance)
- One HDMI TX audio output

## 1.2.9 Peripheral Interfaces

Hi3796M V100 integrates diverse peripheral interfaces for connecting to various peripherals or extending system functions.

### IR

The integrated dedicated infrared remoter (IR) receives data through an IR interface. It has the following features:

- Flexible configuration for decoding data in various formats
- Error check for received data
- IR wakeup
- One input interface

### LED/Keypad Controller

Hi3796M V100 integrates the LED/keypad controller for controlling the LED display and key scanning.

### USB Controller

Hi3796M V100 integrates three USB 2.0 controllers and supports one USB 3.0 controller.

- All the three USB 2.0 controllers support the host function, and one of them supports the Android debug bridge (ADB) debugging.
- The USB 2.0 ports support the low-speed and high-speed modes and extended hub.

### GPIO

Hi3796M V100 integrates multiple groups of GPIO controllers. Each group provides eight programmable input/output pins.

- Each GPIO pin can be configured as an input or output.
- As an input pin, the GPIO can be an interrupt source.
- As an output pin, the GPIO can be independently set to 1 or 0.



## UART

Hi3796M V100 integrates two universal asynchronous receiver transmitters (UARTs) for debugging, controlling, or extending external devices such as the Bluetooth and keyboard. One is a 2-wire interface, and the other is a 4-wire interface.

## I<sup>2</sup>C Controller

Hi3796M V100 integrates three inter-integrated circuit (I<sup>2</sup>C) controllers, which serve as standard master I<sup>2</sup>C devices to transmit or receive data to or from the slave devices over the I<sup>2</sup>C bus.

## SCI

Hi3796M V100 integrates a smart card interface (SCI) controller and provides one SCI. The SCI controller supports the ISO/IEC 7816-3, ISO/IEC 7816-10, and asynchronous T0, T1, and T4 protocols. The CPU reads data from or writes data to the smart card through the SCI and implements serial-to-parallel conversion (when reading data from the smart card) and parallel-to-serial conversion (when writing data to the smart card).

## 1.2.10 Boot Modes

Hi3796M V100 supports various boot modes, which can be configured by connecting pull-up or pull-down resistors to the boot pin, providing flexible boot solutions for system applications.

- Booting from the NAND flash
- Booting from the eMMC
- Booting from the SD card

## 1.2.11 Low-Power Control

Hi3796M V100 supports various low-power modes to dynamically reduce power consumption.

- Various system working modes, including the normal mode, light standby mode, and passive standby mode
- Module low-power control
- DVFS based on CPU load monitoring
- AVS based on CPU timing monitoring
- Ultra-low-power standby design, including various standby wakeup modes such as remote control wakeup and key wakeup

## 1.3 Address Space Mapping

Hi3796M V100 can be booted from the off-chip NAND flash, eMMC, or SD card.

Hi3796M V100 will boot from the on-chip ROM by default after power-on.



**Table 1-1** Address space mapping

| Start Address | End Address | Object                       | Capacity (Byte) | Remarks |
|---------------|-------------|------------------------------|-----------------|---------|
| 0x0000_0000   | 0x7FFF_FFFF | DRAM                         | 2 GB            | -       |
| 0x8000_0000   | 0xF7FF_FFFF | Reserved                     | 1920 MB         |         |
| 0xF800_0000   | 0xF800_0FFF | Sysctrl register             | 4 KB            | -       |
| 0xF800_1000   | 0xF800_1FFF | IR register                  | 4 KB            | -       |
| 0xF800_2000   | 0xF800_2FFF | Timer 0/Timer 1 register     | 4 KB            | -       |
| 0xF800_3000   | 0xF800_3FFF | LEDC register                | 4 KB            | -       |
| 0xF800_4000   | 0xF800_4FFF | GPIO5 register               | 4 KB            | -       |
| 0xF800_5000   | 0xF800_5FFF | TRNG register                | 4 KB            | -       |
| 0xF800_6000   | 0xF800_6FFF | UART1 register               | 4 KB            | -       |
| 0xF800_7000   | 0xF83F_FFFF | Reserved                     | 4068 KB         | -       |
| 0xF840_0000   | 0xF840_FFFF | 8051 Local RAM               | 64 KB           | -       |
| 0xF841_0000   | 0xF89F_FFFF | Reserved                     | 6080 KB         |         |
| 0xF8A0_0000   | 0xF8A0_1FFF | A7MP peripheral register     | 8 KB            | -       |
| 0xF8A0_2000   | 0xF8A1_FFFF | Reserved                     | 120 KB          |         |
| 0xF8A2_0000   | 0xF8A2_0FFF | PERI_CTRL register           | 4 KB            | -       |
| 0xF8A2_1000   | 0xF8A2_1FFF | IO_CONFIG register           | 4 KB            | -       |
| 0xF8A2_2000   | 0xF8A2_2FFF | CRG register                 | 4 KB            | -       |
| 0xF8A2_3000   | 0xF8A2_3FFF | PMC register                 | 4 KB            | -       |
| 0xF8A2_4000   | 0xF8A2_8FFF | Reserved                     | 20 KB           |         |
| 0xF8A2_9000   | 0xF8A2_9FFF | Timer 2 and timer 3 register | 4 KB            | -       |
| 0xF8A2_A000   | 0xF8A2_AFFF | Timer 4 and timer 5 register | 4 KB            | -       |
| 0xF8A2_B000   | 0xF8A2_BFFF | Timer 6 and timer 7 register | 4 KB            | -       |
| 0xF8A2_C000   | 0xF8A2_CFFF | WDG0 register                | 4 KB            | -       |
| 0xF8A2_D000   | 0xF8A2_FFFF | Reserved                     | 12 KB           |         |
| 0xF8A3_0000   | 0xF8A3_FFFF | MDDRC0 register              | 64 KB           | -       |
| 0xF8A4_0000   | 0xF8A4_FFFF | Reserved                     | 64 KB           |         |
| 0xF8A5_0000   | 0xF8A5_FFFF | DDR_TEST register            | 64 KB           | -       |
| 0xF8A6_0000   | 0xF8A7_FFFF | Reserved                     | 128 KB          |         |
| 0xF8A8_0000   | 0xF8A8_0FFF | SEC_CFG register             | 4 KB            | -       |
| 0xF8A8_1000   | 0xF8A8_FFFF | Reserved                     | 60 KB           |         |



| Start Address | End Address | Object                                       | Capacity (Byte) | Remarks |
|---------------|-------------|----------------------------------------------|-----------------|---------|
| 0xF8A9_0000   | 0xF8A9_FFFF | MKL                                          | 64 KB           | -       |
| 0xF8AA_0000   | 0xF8AA_FFFF | Reserved                                     | 64 KB           |         |
| 0xF8AB_0000   | 0xF8AB_FFFF | OTP register                                 | 64 KB           | -       |
| 0xF8AC_0000   | 0xF8AF_FFFF | Reserved                                     | 256 KB          |         |
| 0xF8B0_0000   | 0xF8B0_0FFF | UART0 register                               | 4 KB            | -       |
| 0xF8B0_1000   | 0xF8B0_FFFF | Reserved                                     | 60 KB           | -       |
| 0xF8B1_0000   | 0xF8B1_0FFF | I <sup>2</sup> C0                            | 4 KB            | -       |
| 0xF8B1_1000   | 0xF8B1_1FFF | I <sup>2</sup> C1                            | 4 KB            | -       |
| 0xF8B1_2000   | 0xF8B1_2FFF | I <sup>2</sup> C2                            | 4 KB            | -       |
| 0xF8B1_3000   | 0xF8B1_7FFF | Reserved                                     | 20 KB           |         |
| 0xF8B1_8000   | 0xF8B1_8FFF | SCI0 register                                | 4 KB            | -       |
| 0xF8B1_9000   | 0xF8B1_FFFF | Reserved                                     | 28 KB           |         |
| 0xF8B2_0000   | 0xF8B2_0FFF | GPIO0 register                               | 4 KB            | -       |
| 0xF8B2_1000   | 0xF8B2_1FFF | GPIO1 register                               | 4 KB            | -       |
| 0xF8B2_2000   | 0xF8B2_2FFF | GPIO2 register                               | 4 KB            | -       |
| 0xF8B2_3000   | 0xF8B2_3FFF | GPIO3 register                               | 4 KB            | -       |
| 0xF8B2_4000   | 0xF8B2_4FFF | GPIO4 register                               | 4 KB            | -       |
| 0xF8B2_5000   | 0xF8B2_5FFF | Reserved                                     | 4 KB            |         |
| 0xF8B2_6000   | 0xF8B2_6FFF | GPIO6 register                               | 4 KB            | -       |
| 0xF8B2_7000   | 0xF8C0_FFFF | Reserved                                     | 932 KB          |         |
| 0xF8C1_0000   | 0xF8C1_FFFF | TDE register                                 | 64 KB           | -       |
| 0xF8C2_0000   | 0xF8C2_FFFF | Reserved                                     | 64 KB           |         |
| 0xF8C3_0000   | 0xF8C3_FFFF | VDH register                                 | 64 KB           | -       |
| 0xF8C4_0000   | 0xF8C4_FFFF | JPGD0 register                               | 64 KB           | -       |
| 0xF8C5_0000   | 0xF8C5_FFFF | Reserved                                     | 64 KB           | -       |
| 0xF8C6_0000   | 0xF8C6_FFFF | BPD register                                 | 64 KB           | -       |
| 0xF8C7_0000   | 0xF8C7_FFFF | PGD register                                 | 64 KB           | -       |
| 0xF8C8_0000   | 0xF8C8_FFFF | Video encoding/decoding unit (VEDU) register | 64 KB           | -       |
| 0xF8C9_0000   | 0xF8C9_FFFF | JPEG encoder (JPGE) register                 | 64 KB           | -       |
| 0xF8CA_0000   | 0xF8CA_FFFF | Reserved                                     | 64 KB           | -       |



| Start Address | End Address  | Object                                          | Capacity (Byte) | Remarks |
|---------------|--------------|-------------------------------------------------|-----------------|---------|
| 0xF8CB_0000   | 0xF8CB_FFFF  | VPSS0 register                                  | 64 KB           | -       |
| 0xF8CC_0000   | 0xF8CC_FFFF  | Video display processor (VDP) register          | 64 KB           | -       |
| 0xF8CD_0000   | 0xF8CD_FFFF  | AIAO register                                   | 64 KB           | -       |
| 0xF8CE_0000   | 0xF8CE_FFFF  | HDMI_TX register                                | 64 KB           | -       |
| 0xF8CF_0000   | 0xF91F_FFFF  | Reserved                                        | 5184 KB         | -       |
| 0xF920_0000   | 0xF923_FFFF  | GPU register                                    | 256 KB          | -       |
| 0xF924_0000   | 0xF980_FFFF  | Reserved                                        | 5952 KB         | -       |
| 0xF981_0000   | 0xF981_FFFF  | NANDC register                                  | 64 KB           | -       |
| 0xF982_0000   | 0xF982_FFFF  | SDIO0 REG                                       | 64 KB           | -       |
| 0xF983_0000   | 0xF983_FFFF  | SDIO1 REG                                       | 64 KB           | -       |
| 0xF984_0000   | 0xF984_FFFF  | SF0 register                                    | 64 KB           | -       |
| 0xF985_0000   | 0xF986_FFFF  | Reserved                                        | 128 KB          | -       |
| 0xF987_0000   | 0xF987_FFFF  | Direct memory access controller (DMAC) register | 64 KB           | -       |
| 0xF988_0000   | 0xF988_FFFF  | USB2Host0 OHCI register                         | 64 KB           | -       |
| 0xF989_0000   | 0xF989_FFFF  | USB2Host0 EHCI register                         | 64 KB           | -       |
| 0xF98A_0000   | 0xF98A_FFFF  | USB3_0 register                                 | 64 KB           | -       |
| 0xF98B_0000   | 0xF98B_FFFF  | Reserved                                        | 64 KB           | -       |
| 0xF98C_0000   | 0xF98F_FFFF  | USB2OTG0 register                               | 256 KB          | -       |
| 0xF990_0000   | 0xF991F_FFFF | Reserved                                        | 128 KB          | -       |
| 0xF992_0000   | 0xF992_FFFF  | USB2Host1 OHCI register                         | 64 KB           | -       |
| 0xF993_0000   | 0xF993_FFFF  | USB2Host1 EHCI register                         | 64 KB           | -       |
| 0xF994_0000   | 0xF99F_FFFF  | Reserved                                        | 704 KB          | -       |
| 0xF9A0_0000   | 0xF9A0_FFFF  | MutiCIPHER register                             | 64 KB           | -       |
| 0xF9A1_0000   | 0xF9A1_FFFF  | SHA                                             | 64 KB           | -       |
| 0xF9A2_0000   | 0xF9BF_FFFF  | Reserved                                        | 1920 KB         | -       |
| 0xF9C0_0000   | 0xF9C0_FFFF  | PVR register                                    | 64 KB           | -       |
| 0xF9C1_0000   | 0xFDFF_FFFF  | Reserved                                        | 69568 KB        | -       |
| 0xFE00_0000   | 0xFE0F_FFFF  | NAND flash                                      | 1 MB            | -       |
| 0xFE10_0000   | 0xFFFFD_FFFF | Reserved                                        | 31616 KB        | -       |



| Start Address | End Address  | Object                                                    | Capacity (Byte) | Remarks |
|---------------|--------------|-----------------------------------------------------------|-----------------|---------|
| 0xFFFFE_0000  | 0xFFFFE_FFFF | BOOTRAM (in remap mode) or reserved (in remap clear mode) | 64 KB           | -       |
| 0xFFFFF_0000  | 0xFFFFF_FFFF | BOOTROM (in remap mode) or BOOTRAM (in remap clear mode)  | 64 KB           | -       |



## Contents

---

|                                  |            |
|----------------------------------|------------|
| <b>2 Security Subsystem.....</b> | <b>2-1</b> |
| 2.1 Features .....               | 2-1        |



# **2 Security Subsystem**

## **2.1 Features**

The security subsystem has the following security features:

- Secure boot. After hardware is reset, the chip boots from the embedded on-chip ROM and then from the flash memory. In addition, signature authentication by using the boot loader is supported.
- Control word (CW) protection by using hardware
- Content protection and AES and 3DES algorithms
- JTAG protection
- Trustzone feature
- OTP and unique ID



# Contents

|                                         |            |
|-----------------------------------------|------------|
| <b>3 System .....</b>                   | <b>3-1</b> |
| 3.1 Processor Subsystem.....            | 3-1        |
| 3.1.1 ARM Cortex A7 Processor.....      | 3-1        |
| 3.1.2 L2 Cache.....                     | 3-1        |
| 3.2 Reset.....                          | 3-2        |
| 3.2.1 Overview.....                     | 3-2        |
| 3.2.2 Reset Control .....               | 3-2        |
| 3.2.3 Reset Configuration .....         | 3-3        |
| 3.3 Clock .....                         | 3-8        |
| 3.3.1 Overview.....                     | 3-8        |
| 3.3.2 Clock Control Block Diagram ..... | 3-8        |
| 3.3.3 Clock Configurations .....        | 3-9        |
| 3.3.4 Register Summary.....             | 3-23       |
| 3.3.5 Register Description.....         | 3-25       |
| 3.4 System Controller.....              | 3-70       |
| 3.4.1 Overview.....                     | 3-70       |
| 3.4.2 Features.....                     | 3-70       |
| 3.4.3 Function Description.....         | 3-70       |
| 3.4.4 Register Summary.....             | 3-72       |
| 3.4.5 Register Description.....         | 3-75       |
| 3.5 Peripheral Controller.....          | 3-107      |
| 3.5.1 Overview.....                     | 3-107      |
| 3.5.2 Features.....                     | 3-107      |
| 3.5.3 Register Summary.....             | 3-108      |
| 3.5.4 Register Description.....         | 3-109      |
| 3.6 Interrupt System .....              | 3-142      |
| 3.7 Timer .....                         | 3-149      |
| 3.7.1 Overview.....                     | 3-149      |
| 3.7.2 Features.....                     | 3-149      |
| 3.7.3 Function Description.....         | 3-149      |
| 3.7.4 Working Process .....             | 3-150      |
| 3.7.5 Register Summary.....             | 3-151      |



|                                 |       |
|---------------------------------|-------|
| 3.7.6 Register Description..... | 3-151 |
| 3.8 DMA Controller .....        | 3-159 |
| 3.8.1 Overview.....             | 3-159 |
| 3.8.2 Features.....             | 3-160 |
| 3.8.3 Function Description..... | 3-160 |
| 3.8.4 Operating Mode .....      | 3-163 |
| 3.8.5 Register Summary.....     | 3-165 |
| 3.8.6 Register Description..... | 3-166 |



## Figures

|                                                                                 |       |
|---------------------------------------------------------------------------------|-------|
| <b>Figure 3-1</b> Block diagram for controlling reset signals .....             | 3-2   |
| <b>Figure 3-2</b> Functional block diagram of the clock management module ..... | 3-9   |
| <b>Figure 3-3</b> Functional block diagram of the DMAC .....                    | 3-161 |
| <b>Figure 3-4</b> Updating channel registers by using LLI .....                 | 3-162 |
| <b>Figure 3-5</b> Connections between the DMAC and other modules .....          | 3-163 |
| <b>Figure 3-6</b> Structure of the linked list for the DMAC .....               | 3-175 |



# Tables

|                                                                           |      |
|---------------------------------------------------------------------------|------|
| <b>Table 3-1</b> Reset signal types .....                                 | 3-3  |
| <b>Table 3-2</b> Soft reset configurations .....                          | 3-4  |
| <b>Table 3-3</b> Frequency configurations of NANDC clocks.....            | 3-10 |
| <b>Table 3-4</b> Frequency configuration of DDR clocks .....              | 3-10 |
| <b>Table 3-5</b> Frequency configurations of UART clocks .....            | 3-10 |
| <b>Table 3-6</b> Frequency configurations of I <sup>2</sup> C clocks..... | 3-11 |
| <b>Table 3-7</b> Frequency configuration of the SSP clock.....            | 3-11 |
| <b>Table 3-8</b> Frequency configuration of the SCI clock.....            | 3-11 |
| <b>Table 3-9</b> Frequency configurations of VDH clocks .....             | 3-11 |
| <b>Table 3-10</b> Frequency configurations of JPGD clocks .....           | 3-12 |
| <b>Table 3-11</b> Frequency configuration of the PGD clock .....          | 3-12 |
| <b>Table 3-12</b> Frequency configuration of the BPD clock .....          | 3-12 |
| <b>Table 3-13</b> Frequency configurations of VENC clocks .....           | 3-12 |
| <b>Table 3-14</b> Frequency configuration of the JPGE clock .....         | 3-13 |
| <b>Table 3-15</b> Frequency configurations of TDE clocks .....            | 3-13 |
| <b>Table 3-16</b> Frequency configurations of SDIO0 clocks.....           | 3-13 |
| <b>Table 3-17</b> Frequency configurations of SDIO1 clocks.....           | 3-14 |
| <b>Table 3-18</b> Frequency configuration of the DMA clock .....          | 3-14 |
| <b>Table 3-19</b> Frequency configurations of USB3CTRL clocks .....       | 3-14 |
| <b>Table 3-20</b> Frequency configurations of USB2 CTRL0 clocks .....     | 3-15 |
| <b>Table 3-21</b> Frequency configurations of USB2 PHY0 clocks .....      | 3-15 |
| <b>Table 3-22</b> Frequency configuration of the CA clock .....           | 3-16 |
| <b>Table 3-23</b> Frequency configuration of the SHA clock .....          | 3-16 |
| <b>Table 3-24</b> Frequency configuration of the PMC clock.....           | 3-16 |
| <b>Table 3-25</b> Frequency configurations of ETH clocks .....            | 3-16 |
| <b>Table 3-26</b> Frequency configurations of GPU clocks.....             | 3-17 |



|                                                                                                   |       |
|---------------------------------------------------------------------------------------------------|-------|
| <b>Table 3-27</b> Frequency configurations of VDP clocks .....                                    | 3-17  |
| <b>Table 3-28</b> Frequency configurations of VPSS clocks .....                                   | 3-18  |
| <b>Table 3-29</b> Frequency configurations of PVR-1 clocks.....                                   | 3-18  |
| <b>Table 3-30</b> Frequency configuration of the PVR-2 clock .....                                | 3-19  |
| <b>Table 3-31</b> Frequency configurations of HDMI TX CTRL clocks .....                           | 3-19  |
| <b>Table 3-32</b> Frequency configuration of the HDMI TX PHY clock.....                           | 3-20  |
| <b>Table 3-33</b> Frequency configuration of the ADAC clock .....                                 | 3-20  |
| <b>Table 3-34</b> Frequency configurations of AIAO clocks .....                                   | 3-20  |
| <b>Table 3-35</b> Frequency configurations of the VDAC clocks.....                                | 3-20  |
| <b>Table 3-36</b> Frequency configurations of FE PHY clocks .....                                 | 3-21  |
| <b>Table 3-37</b> Frequency configuration of the GPU clock .....                                  | 3-21  |
| <b>Table 3-38</b> Frequency configuration of the DDR clock.....                                   | 3-21  |
| <b>Table 3-39</b> Frequency configurations of WDG clocks .....                                    | 3-21  |
| <b>Table 3-40</b> Frequency configurations of USB2 PHY1 clocks .....                              | 3-22  |
| <b>Table 3-41</b> Frequency configurations of USB3 PHY clocks .....                               | 3-22  |
| <b>Table 3-42</b> Frequency configurations of USB2 CTRL1 clocks .....                             | 3-22  |
| <b>Table 3-43</b> Summary of CRG registers (base address: 0xF8A2_2000) .....                      | 3-23  |
| <b>Table 3-44</b> Summary of SYS_CTRL registers (base address: 0xF800_0000).....                  | 3-72  |
| <b>Table 3-45</b> Summary of PERI_CTRL registers (base address: 0xF8A2_0000).....                 | 3-108 |
| <b>Table 3-46</b> Interrupt sources of Cortex A7 .....                                            | 3-142 |
| <b>Table 3-47</b> Interrupt sources of the MCU .....                                              | 3-147 |
| <b>Table 3-48</b> Summary of timer registers .....                                                | 3-151 |
| <b>Table 3-49</b> Summary of DMAC registers (base address: 0xF987_0000) .....                     | 3-165 |
| <b>Table 3-50</b> Mapping between the value of DBSize or SBSIZE and the burst size.....           | 3-179 |
| <b>Table 3-51</b> Mapping between DWidth or SWidth and the transfer bit width.....                | 3-179 |
| <b>Table 3-52</b> Definitions of the prot field of DMAC_CX_CONTROL.....                           | 3-180 |
| <b>Table 3-53</b> Flow controllers and transfer types corresponding to the flow_cntrl field ..... | 3-183 |



# 3 System

## 3.1 Processor Subsystem

### 3.1.1 ARM Cortex A7 Processor

Hi3796M V100 adopts the ARM Cortex-A7 quad-core processor, which has the following features:

- Maximum 1.5 GHz, 11400 DMIPS working frequency
- 32 KB I-cache and 32 KB D-cache (supporting the read-allocate mode) for the L1 cache
- Integrated NEON with the floating-point unit (FPU) coprocessor
- Management unit (MMU)
- Integrated generic interrupt controller (GIC), which supports 160 interrupt sources
- DVFS and AVS
- Support for OSs such as Linux and Android
- JTAG debugging interface
- Integrated L2 cache

### 3.1.2 L2 Cache

The integrated L2 cache in the Cortex-A7 processor has the following features:

- Provides the 512 KB capacity.
- Works based on the physical address and physical tag.
- Provides the 64-byte (16 words or 512 bits) cache line and supports the write operation by byte.
- Supports the 8-way set-associative structure.
- Supports write-back, read-allocate, and write-allocate operations. The actual mode depends on the page table.
- Supports the forcible read-allocate function, which forces all cacheable write operations to be transparently transmitted to the downstream module.
- Supports enable/disable of the L1 cache and L2 cache at the same time. If the caches are disabled, they are bypassed, and all the operations on L1 are transferred to the DDR memory transparently.
- Supports the read-allocate function for the L2 D-cache.

- Supports the atomic exclusive operation but not atomic lock operation.
- Supports clean and invalidate operations by way, way+index, or address.
- Supports prefetching of instructions and data and configurable prefetch mode.

## 3.2 Reset

### 3.2.1 Overview

The reset management module resets the entire chip and all functional modules in a unified manner as follows:

- Manages and controls power-on reset (POR).
- Controls the system soft reset and separate soft reset of each functional module.
- Controls the soft reset of power-off areas in low-power mode.
- Synchronizes reset signals to the clock domain of each module.
- Generates reset signals for each internal functional module.

### 3.2.2 Reset Control

Figure 3-1 shows the block diagram for controlling reset signals.

**Figure 3-1** Block diagram for controlling reset signals



RSTN: POR signal. It is the output signal of the POR module in the chip.

sysrst\_req: system soft reset request signal. It is derived from the system controller.

pd\_rst\_req: reset request signal for power-off areas. It is derived from the system controller.

xxx\_srst\_req: separate soft reset request signal of each module. It is derived from the system controller or



CRG controller, for example, tde\_srst\_req.

[Table 3-1](#) describes the output reset signals.

**Table 3-1** Reset signal types

| Reset Signal Type | Generation Mode                                                                                                                                                  | Purpose                                                                                                                                                 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| rst_por_n         | Generated by dejittering and synchronizing the RSTN signal                                                                                                       | Resets the system controller.                                                                                                                           |
| sys_RST_com       | Generated by logically combining the POR signal with the system soft reset signal                                                                                | Resets the modules in the always-on area that support global soft reset but not separate soft reset.                                                    |
| xx_RST_n          | Generated by combining the system reset signal sys_RST_com and the separate soft reset signal of each module, for resetting IP modules in the always-on area     | Resets the modules that support separate soft reset in the always-on area. Those modules are reset upon POR, global soft reset, or separate soft reset. |
| rst_por_n_ini     | Generated by dejittering and synchronizing the RSTN signal                                                                                                       | Resets the A7 and NANDC in the power-off area.                                                                                                          |
| sys_RST_com_ini   | Generated by logically combining a POR signal with a system soft reset signal                                                                                    | Resets the modules in the power-off area that support global soft reset but not separate soft reset.                                                    |
| xx_RST_ini_n      | Generated by combining the system reset signal sys_RST_com_ini and the separate soft reset signal of each module, for resetting IP modules in the power-off area | Resets the modules that support separate soft reset in the power-off area. Those modules are reset upon POR, global soft reset, or separate soft reset. |

### 3.2.3 Reset Configuration

#### POR

RSTN is the output signal of the POR module in the HD chip. POR is implemented only when all of the following conditions are met:

- The POR module outputs a low-level pulse.
- The input clock from the crystal oscillator clock input pin XIN is correct.

#### System Reset

The system is reset in either of the following ways:

- POR
- System soft reset, which is controlled by the system controller [SC\\_SYSRES](#)



## Soft Reset

Soft reset is controlled by configuring the corresponding system controller. For details, see [Table 3-2](#).



### CAUTION

- After a system soft reset request is sent, the circuit reset can be deasserted only after 20 system clock cycles.
- The separate soft reset of each module cannot be automatically deasserted. That is, each module is reset when a certain bit is set to 1, and the module reset is deasserted only when the bit is set to 0.
- During power-on, the USB 2.0 PHY and the controller are reset by default. They start to work properly only when the reset is deasserted.

**Table 3-2** Soft reset configurations

| Signal          | Description                                                                                                                                                                                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sysrst_req      | System soft reset request, valid at the rising edge. When the control bit is changed from 0 to 1, a valid reset is executed. Then this reset is automatically deasserted in the chip. This signal can be controlled by configuring <a href="#">SC_SYSRES</a> . |
| m8051_srst_req  | Soft reset control for the microprogrammed control unit (MCU). This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[1].                                                                                                       |
| ir_srst_req     | Soft reset control for the IR module. This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[5].                                                                                                                                |
| timer_srst_req  | Soft reset control for the timer module. This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[7].                                                                                                                             |
| led_srst_req    | Soft reset control for the light emitting diode control (LEDCCTRL) module. This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[9].                                                                                           |
| uart_srst_req   | Soft reset control for the UART module. This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[13].                                                                                                                             |
| pd_RST_req      | Reset control for the power-off area. This signal can be controlled by configuring <a href="#">SC_CLKGATE_SRST_CTRL</a> bit[28].                                                                                                                               |
| nf_srst_req     | Soft reset control for the NANDC. This signal can be controlled by configuring <a href="#">PERI_CRG24</a> bit[4].                                                                                                                                              |
| hipack_srst_req | Soft reset control for the HIPACK module. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[8].                                                                                                                                      |



| Signal         | Description                                                                                                                                         |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| ddrc_srst_req  | Soft reset control for the DDRC. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[9].                                    |
| ddrt_srst_req  | Soft reset control for the double data rate test (DDRT) module. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[10].    |
| uart1_srst_req | Soft reset control for UART1. This signal can be controlled by configuring <a href="#">PERI_CRG26</a> bit[1].                                       |
| uart2_srst_req | Soft reset control for UART2. This signal can be controlled by configuring <a href="#">PERI_CRG26</a> bit[5].                                       |
| i2c0_srst_req  | Soft reset control for I <sup>2</sup> C0. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[5].                           |
| i2c1_srst_req  | Soft reset control for I <sup>2</sup> C1. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[9].                           |
| i2c2_srst_req  | Soft reset control for I <sup>2</sup> C2. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[13].                          |
| ssp0_srst_req  | Soft reset control for SSP0. This signal can be controlled by configuring <a href="#">PERI_CRG28</a> bit[1].                                        |
| sci0_srst_req  | Soft reset control for SCI0. This signal can be controlled by configuring <a href="#">PERI_CRG29</a> bit[1].                                        |
| vdh_srst_req   | Soft reset control for the video decoder for high-definition (VDH). This signal can be controlled by configuring <a href="#">PERI_CRG30</a> bit[4]. |
| jpgd_srst_req  | Soft reset control for JPGD0. This signal can be controlled by configuring <a href="#">PERI_CRG31</a> bit[4].                                       |
| pgd_srst_req   | Soft reset control for the PNG and GIF decoder (PGD). This signal can be controlled by configuring <a href="#">PERI_CRG33</a> bit[4].               |
| bpd_srst_req   | Soft reset control for the bit plan decoder (BPD). This signal can be controlled by configuring <a href="#">PERI_CRG34</a> bit[4].                  |
| venc_srst_req  | Soft reset control for the video encoder (VENC). This signal can be controlled by configuring <a href="#">PERI_CRG35</a> bit[4].                    |
| jpge_srst_req  | Soft reset control for the JPEG encoder (JPGE). This signal can be controlled by configuring <a href="#">PERI_CRG36</a> bit[4].                     |
| tde_srst_req   | Soft reset control for the two-dimensional engine (TDE). This signal can be controlled by configuring <a href="#">PERI_CRG37</a> bit[4].            |
| sdio0_srst_req | Soft reset control for SDIO0. This signal can be controlled by configuring <a href="#">PERI_CRG39</a> bit[4].                                       |
| sdio1_srst_req | Soft reset control for SDIO1. This signal can be controlled by configuring <a href="#">PERI_CRG40</a> bit[4].                                       |



| Signal                | Description                                                                                                                                                           |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dma_srst_req          | Soft reset control for the direct memory access (DMA) module. This signal can be controlled by configuring <a href="#">PERI_CRG41</a> bit[4].                         |
| usb3_vcc_srst_req     | Soft reset control for USB3CTRL VCC. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[12].                                                 |
| usb2_bus_srst_req     | Soft reset control for the USB2 CTRL0 bus. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[12].                                           |
| usb2_utmi0_srst_req   | Soft reset control for USB2 CTRL0 USB 2.0 transceiver macrocell interface 0 (UTMI0). This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[13]. |
| usb2_utmi1_srst_req   | Soft reset control for USB2 CTRL0 UTMI1. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[14].                                             |
| usb2_hst_phy_srst_req | Soft reset control for the USB2 CTRL0 HST_PHY. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[16].                                       |
| usb2_otg_phy_srst_req | Soft reset control for the USB2 CTRL0 OTG_PHY. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[17].                                       |
| usb2_phy_srst_req     | Soft reset control for the USB2 PHY0 port. This signal can be controlled by configuring <a href="#">PERI_CRG47</a> bit[8].                                            |
| usb2_phy_srst_treq0   | Soft reset control for the USB2 PHY0 TPORT. This signal can be controlled by configuring <a href="#">PERI_CRG47</a> bit[9].                                           |
| usb2_phy_srst_treq1   | Soft reset control for the USB2 PHY1 TPORT. This signal can be controlled by configuring <a href="#">PERI_CRG47</a> bit[11].                                          |
| otp_srst_req          | Soft reset control for the OTP module. This signal can be controlled by configuring <a href="#">PERI_CRG48</a> bit[10].                                               |
| ca_ci_srst_req        | Soft reset control for the cipher. This signal can be controlled by configuring <a href="#">PERI_CRG48</a> bit[9].                                                    |
| sha_srst_req          | Soft reset control for the secure hash algorithm (SHA) module. This signal can be controlled by configuring <a href="#">PERI_CRG49</a> bit[4].                        |
| pmc_srst_req          | Soft reset control for the power management control (PMC) module. This signal can be controlled by configuring <a href="#">PERI_CRG50</a> bit[4].                     |
| hrst_eth_s            | Soft reset control for the ETH module. This signal can be controlled by configuring <a href="#">PERI_CRG51</a> bit[4].                                                |
| gpu_srst_req          | Soft reset control for the GPU. This signal can be controlled by configuring <a href="#">PERI_CRG53</a> bit[4].                                                       |
| vou_srst_req          | Soft reset control for the video output unit (VOU). This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[30].                                  |



| Signal                   | Description                                                                                                                                          |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| vpss_srst_req            | Soft reset control for the video processing subsystem (VPSS). This signal can be controlled by configuring <a href="#">PERI_CRG60</a> bit[4].        |
| pvr_srst_req             | Soft reset control for the personal video recorder (PVR). This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[22].           |
| hdmitx_ctrl_bus_srst_req | Soft reset control for the HDMITX_CTRL bus. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[8].                          |
| hdmitx_ctrl_srst_req     | Soft reset control for HDMITX_CTRL. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[9].                                  |
| hdmitx_phy_srst_req      | Soft reset control for the HDMI TX PHY. This signal can be controlled by configuring <a href="#">PERI_CRG68</a> bit[4].                              |
| adac_srst_req            | Soft reset control for the audio digital-to-analog converter (ADAC). This signal can be controlled by configuring <a href="#">PERI_CRG69</a> bit[4]. |
| aiao_srst_req            | Soft reset control for the audio input/audio output (AIAO) module. This signal can be controlled by configuring <a href="#">PERI_CRG70</a> bit[4].   |
| fephy_srst_req           | Soft reset control for the FE PHY. This signal can be controlled by configuring <a href="#">PERI_CRG72</a> bit[4].                                   |
| wdg0_srst_req            | Soft reset control for WDG0. This signal can be controlled by configuring <a href="#">PERI_CRG94</a> bit[4].                                         |
| usb2_phy1_srst_req       | Soft reset control for the USB2 PHY1 port. This signal can be controlled by configuring <a href="#">PERI_CRG100</a> bit[8].                          |
| usb2_phy1_srst_treq      | Soft reset control for the USB2 PHY1 TPORT. This signal can be controlled by configuring <a href="#">PERI_CRG100</a> bit[9].                         |
| usb3_phy_srst_req        | Soft reset control for the USB3 PHY port. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[4].                           |
| usb3_phy_srst_treq       | Soft reset control for the USB3 PHY TPORT. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[5].                          |
| usb2_bus_srst_req1       | Soft reset control for the USB2 CTRL1 bus. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[12].                         |
| usb2_utmi0_srst_req1     | Soft reset control for USB2 CTRL1 UTMIO. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[14].                           |
| usb2_hst_phy_srst_req1   | Soft reset control for the USB2 CTRL1 HST_PHY. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[16].                     |

## 3.3 Clock

### 3.3.1 Overview

The clock management module provides the following functions:

- Manages and controls clock inputs.
- Divides and controls clock frequencies.
- Generates working clocks for each module.

### 3.3.2 Clock Control Block Diagram

Figure 3-2 shows the functional block diagram of the clock management module.

**Figure 3-2** Functional block diagram of the clock management module



The inputs of the clock management module include:

- Clock inputs from pins
- Clock control inputs from the system controller



The clock management module consists of the following three parts:

- PLLs including the APLL, BPLL, VPLL, EPLL, DPLL, and HPLL that generate the required clocks with different frequencies for the system
- ARM frequency control unit (ARMCLK Freq Ctrl) and module clock frequency control unit (IPCLK Freq Ctrl)
- Clock gating management unit

### 3.3.3 Clock Configurations

#### 3.3.3.1 Configuring the NANDC Clock Frequency

[Table 3-3](#) describes frequency configurations of NANDC clocks.

**Table 3-3** Frequency configurations of NANDC clocks

| Signal     | Description                                                                                            |
|------------|--------------------------------------------------------------------------------------------------------|
| nf_clk_sel | NANDC clock select. This signal can be controlled by configuring <a href="#">PERI_CRG24</a> bit[10:8]. |
| nf_cken    | NANDC clock state. This signal can be controlled by configuring <a href="#">PERI_CRG24</a> bit[0].     |

#### 3.3.3.2 Configuring the DDR Clock Frequency

[Table 3-4](#) describes frequency configurations of DDR clocks.

**Table 3-4** Frequency configuration of DDR clocks

| Signal      | Description                                                                                           |
|-------------|-------------------------------------------------------------------------------------------------------|
| ddrt_cken   | DDRT clock status. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[12].   |
| ddrc_cken   | DDRC clock status. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[3].    |
| hipack_cken | HIPACK clock status. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[2].  |
| ddrphy_cken | DDR PHY clock status. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[1]. |
| ddr_cken    | DDR clock status. This signal can be controlled by configuring <a href="#">PERI_CRG25</a> bit[0].     |

#### 3.3.3.3 Configuring the UART Clock Frequency

[Table 3-5](#) describes frequency configurations of UART clocks.



**Table 3-5** Frequency configurations of UART clocks

| Signal     | Description                                                                                         |
|------------|-----------------------------------------------------------------------------------------------------|
| uart1_cken | UART1 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG26</a> bit[0]. |
| uart2_cken | UART2 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG26</a> bit[4]. |

### 3.3.3.4 Configuring the I<sup>2</sup>C Clock Frequency

[Table 3-6](#) describes frequency configurations of I<sup>2</sup>C clocks.

**Table 3-6** Frequency configurations of I<sup>2</sup>C clocks

| Signal    | Description                                                                                                      |
|-----------|------------------------------------------------------------------------------------------------------------------|
| i2c2_cken | I <sup>2</sup> C2 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[12]. |
| i2c1_cken | I <sup>2</sup> C1 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[8].  |
| i2c0_cken | I <sup>2</sup> C0 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG27</a> bit[4].  |

### 3.3.3.5 Configuring the SSP Clock Frequency

[Table 3-7](#) describes the frequency configuration of the SSP clock.

**Table 3-7** Frequency configuration of the SSP clock

| Signal    | Description                                                                                        |
|-----------|----------------------------------------------------------------------------------------------------|
| ssp0_cken | SSP0 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG28</a> bit[0]. |

### 3.3.3.6 Configuring the SCI Clock Frequency

[Table 3-8](#) describes frequency configuration of the SCI clock.

**Table 3-8** Frequency configuration of the SCI clock

| Signal    | Description                                                                                       |
|-----------|---------------------------------------------------------------------------------------------------|
| sci0_cken | SCI0 clock state. This signal can be controlled by configuring <a href="#">PERI_CRG29</a> bit[0]. |



### 3.3.3.7 Configuring the VDH Clock Frequency

[Table 3-9](#) describes frequency configurations of VDH clocks.

**Table 3-9** Frequency configurations of VDH clocks

| Signal      | Description                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------|
| vdh_clk_sel | VDH clock select. This signal can be controlled by configuring <a href="#">PERI_CRG30</a> bit[9:8]. |
| vdh_cken    | VDH clock status. This signal can be controlled by configuring <a href="#">PERI_CRG30</a> bit[0].   |

### 3.3.3.8 Configuring the JPGD Clock Frequency

[Table 3-10](#) describes frequency configurations of JPGD clocks.

**Table 3-10** Frequency configurations of JPGD clocks

| Signal       | Description                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------|
| jpgd_clk_sel | JPGD clock select. This signal can be controlled by configuring <a href="#">PERI_CRG31</a> bit[8]. |
| jpgd_cken    | JPGD clock status. This signal can be controlled by configuring <a href="#">PERI_CRG31</a> bit[0]. |

### 3.3.3.9 Configuring the PGD Clock Frequency

[Table 3-11](#) describes the frequency configuration of the PGD clock.

**Table 3-11** Frequency configuration of the PGD clock

| Signal   | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| pgd_cken | PGD clock status. This signal can be controlled by configuring <a href="#">PERI_CRG33</a> bit[0]. |

### 3.3.3.10 Configuring the BPD Clock Frequency

[Table 3-12](#) describes the frequency configuration of the BPD clock.

**Table 3-12** Frequency configuration of the BPD clock

| Signal   | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| bpd_cken | BPD clock status. This signal can be controlled by configuring <a href="#">PERI_CRG34</a> bit[0]. |



### 3.3.3.11 Configuring the VENC Clock Frequency

Table 3-13 describes frequency configurations of VENC clocks.

**Table 3-13** Frequency configurations of VENC clocks

| Signal       | Description                                                                                    |
|--------------|------------------------------------------------------------------------------------------------|
| venc_clk_sel | VENC clock frequency select. This signal can be controlled by configuring PERI_CRG35 bit[8:7]. |
| venc_cken    | VENC clock status. This signal can be controlled by configuring PERI_CRG35 bit[0].             |

### 3.3.3.12 Configuring the JPGE Clock Frequency

Table 3-14 describes the frequency configuration of the JPGE clock.

**Table 3-14** Frequency configuration of the JPGE clock

| Signal    | Description                                                                        |
|-----------|------------------------------------------------------------------------------------|
| jpge_cken | JPGE clock status. This signal can be controlled by configuring PERI_CRG36 bit[0]. |

### 3.3.3.13 Configuring the TDE Clock Frequency

Table 3-15 describes frequency configurations of TDE clocks.

**Table 3-15** Frequency configurations of TDE clocks

| Signal      | Description                                                                         |
|-------------|-------------------------------------------------------------------------------------|
| tde_clk_sel | TDE clock select. This signal can be controlled by configuring PERI_CRG37 bit[9:8]. |
| tde_cken    | TDE clock status. This signal can be controlled by configuring PERI_CRG37 bit[0].   |

### 3.3.3.14 Configuring the SDIO0 Clock Frequency

Table 3-16 describes frequency configurations of SDIO0 clocks.

**Table 3-16** Frequency configurations of SDIO0 clocks

| Signal        | Description                                                                           |
|---------------|---------------------------------------------------------------------------------------|
| sdio0_clk_sel | SDIO0 clock select. This signal can be controlled by configuring PERI_CRG39 bit[9:8]. |



| Signal         | Description                                                                                             |
|----------------|---------------------------------------------------------------------------------------------------------|
| sdio0_cken     | SDIO0 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG39</a> bit[1].     |
| sdio0_bus_cken | SDIO0 bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG39</a> bit[0]. |

### 3.3.3.15 Configuring the SDIO1 Clock Frequency

[Table 3-17](#) describes frequency configurations of SDIO1 clocks.

**Table 3-17** Frequency configurations of SDIO1 clocks

| Signal         | Description                                                                                             |
|----------------|---------------------------------------------------------------------------------------------------------|
| sdio1_clk_sel  | SDIO1 clock select. This signal can be controlled by configuring <a href="#">PERI_CRG40</a> bit[9:8].   |
| sdio1_cken     | SDIO1 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG40</a> bit[1].     |
| sdio1_bus_cken | SDIO1 bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG40</a> bit[0]. |

### 3.3.3.16 Configuring the DMA Clock Frequency

[Table 3-18](#) describes the frequency configuration of the DMA clock.

**Table 3-18** Frequency configuration of the DMA clock

| Signal   | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| dma_cken | DMA clock status. This signal can be controlled by configuring <a href="#">PERI_CRG41</a> bit[0]. |

### 3.3.3.17 Configuring the USB3CTRL Clock Frequency

[Table 3-19](#) describes frequency configurations of USB3CTRL clocks.

**Table 3-19** Frequency configurations of USB3CTRL clocks

| Signal            | Description                                                                                                    |
|-------------------|----------------------------------------------------------------------------------------------------------------|
| usb3_pcs_ref_cken | USB3CTRL PCS_REF clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[9]. |
| usb3_pcs_rx_cken  | USB3CTRL PCS_RX clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[8].  |



| Signal             | Description                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------|
| usb3_pcs_pclk_cken | USB3CTRL PCS_PCLK clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[7]. |
| usb3_bus_gm_cken   | USB3CTRL GM bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[6].   |
| usb3_bus_gs_cken   | USB3CTRLGS bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[5].    |
| usb3_utmi_cken     | USB3CTRL UTMI clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[4].     |
| usb3_suspend_cken  | USB3CTRL SUSPEND clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[2].  |
| usb3_ref_cken      | USB3CTRL REF clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[1].      |
| usb3_bus_cken      | USB3CTRL bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG44</a> bit[0].      |

### 3.3.3.18 Configuring the USB2CTRL0 Clock Frequency

[Table 3-20](#) describes frequency configurations of USB2 CTRL0 clocks.

**Table 3-20** Frequency configurations of USB2 CTRL0 clocks

| Signal            | Description                                                                                                      |
|-------------------|------------------------------------------------------------------------------------------------------------------|
| usb2_utmi0_cken   | USB2 CTRL0 UTMIO clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[5].   |
| usb2_hst_phy_cken | USB2 CTRL0 HSTPHY clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[4].  |
| usb2_otg_phy_cken | USB2 CTRL0 OTGPHY clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[3].  |
| usb2_ohci12m_cken | USB2 CTRL0 OHCI12M clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[2]. |
| usb2_ohci48m_cken | USB2 CTRL0 OHCI48M clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[1]. |
| usb2_bus_cken     | USB2 CTRL0 bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG46</a> bit[0].     |

### 3.3.3.19 Configuring the USB2 PHY0 Clock Frequency

[Table 3-21](#) describes frequency configurations of USB2 PHY0 clocks.



**Table 3-21** Frequency configurations of USB2 PHY0 clocks

| Signal              | Description                                                                                               |
|---------------------|-----------------------------------------------------------------------------------------------------------|
| usb2_phy_refclk_sel | USB2 PHY0 REFCLK select. This signal can be controlled by configuring <a href="#">PERI_CRG47</a> bit[16]. |
| usb2_phy_ref_cken   | USB2 PHY0 REFCLK status. This signal can be controlled by configuring <a href="#">PERI_CRG47</a> bit[0].  |

### 3.3.3.20 Configuring the CA Clock Frequency

[Table 3-22](#) describes the frequency configuration of the CA clock.

**Table 3-22** Frequency configuration of the CA clock

| Signal        | Description                                                                                       |
|---------------|---------------------------------------------------------------------------------------------------|
| ca_ci_clk_sel | CA clock select. This signal can be controlled by configuring <a href="#">PERI_CRG48</a> bit[12]. |

### 3.3.3.21 Configuring the SHA Clock Frequency

[Table 3-23](#) describes the frequency configuration of the SHA clock.

**Table 3-23** Frequency configuration of the SHA clock

| Signal   | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| sha_cken | SHA clock status. This signal can be controlled by configuring <a href="#">PERI_CRG49</a> bit[0]. |

### 3.3.3.22 Configuring the PMC Clock Frequency

[Table 3-24](#) describes the frequency configuration of the PMC clock.

**Table 3-24** Frequency configuration of the PMC clock

| Signal   | Description                                                                                       |
|----------|---------------------------------------------------------------------------------------------------|
| pmc_cken | PMC clock status. This signal can be controlled by configuring <a href="#">PERI_CRG50</a> bit[0]. |

### 3.3.3.23 Configuring the ETH Clock Frequency

[Table 3-25](#) describes frequency configurations of ETH clocks.



**Table 3-25** Frequency configurations of ETH clocks

| Signal       | Description                                                                                               |
|--------------|-----------------------------------------------------------------------------------------------------------|
| eth_clk_sel  | ETH clock select. This signal can be controlled by configuring <a href="#">PERI_CRG51</a> bit[3:2].       |
| eth_cken     | ETH working clock status. This signal can be controlled by configuring <a href="#">PERI_CRG51</a> bit[1]. |
| eth_bus_cken | ETH bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG51</a> bit[0].     |

### 3.3.3.24 Configuring the GPU Clock Frequency

[Table 3-26](#) describes frequency configurations of GPU clocks.

**Table 3-26** Frequency configurations of GPU clocks

| Signal       | Description                                                                                           |
|--------------|-------------------------------------------------------------------------------------------------------|
| gpu_cken     | GPU clock status. This signal can be controlled by configuring <a href="#">PERI_CRG53</a> bit[0].     |
| gpu_pp0_cken | GPU PP0 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG53</a> bit[8]. |
| gpu_pp1_cken | GPU PP1 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG53</a> bit[9]. |

### 3.3.3.25 Configuring the VDP Clock Frequency

[Table 3-27](#) describes frequency configurations of VDP clocks.

**Table 3-27** Frequency configurations of VDP clocks

| Signal             | Description                                                                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| vo_hd_hdmi_clk_sel | Ratio of the HDMI clock frequency to the VO clock frequency of the HD channel. This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[29]. |
| vdp_clk_sel        | VDP clock select. This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[28].                                                              |
| vo_sd_hdmi_clk_sel | Ratio of the HDMI clock frequency to the VO clock frequency of the SD channel. This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[27]. |
| hdmi_clk_sel       | HDMI clock select. This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[26].                                                             |
| vdac_ch0_clk_sel   | VDAC CH0 clock select. This signal can be controlled by configuring <a href="#">PERI_CRG54</a> bit[20].                                                         |



| Signal        | Description                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------|
| vo_hd_div     | Ratio of the VO HD clock frequency to the VOHD_DATE clock frequency. This signal can be controlled by configuring PERI_CRG54 bit[19:18]. |
| vo_hd_clk_sel | VOHD clock select. This signal can be controlled by configuring PERI_CRG54 bit[17:16].                                                   |
| vo_sd_clk_div | VO SD clock frequency divider select. This signal can be controlled by configuring PERI_CRG54 bit[15:14].                                |
| vo_sd_clk_sel | VOSD clock select. This signal can be controlled by configuring PERI_CRG54 bit[13:12].                                                   |
| vo_ch0_cken   | VDAC CH0 clock status. This signal can be controlled by configuring PERI_CRG54 bit[6].                                                   |
| vo_hdate_cken | VO HD DATE clock status. This signal can be controlled by configuring PERI_CRG54 bit[5].                                                 |
| vo_hd_cken    | VO HD clock status. This signal can be controlled by configuring PERI_CRG54 bit[4].                                                      |
| vo_sdate_cken | VO SD DATE clock status. This signal can be controlled by configuring PERI_CRG54 bit[3].                                                 |
| vo_sd_cken    | VO SD clock status. This signal can be controlled by configuring PERI_CRG54 bit[2].                                                      |
| vo_cken       | VO clock status. This signal can be controlled by configuring PERI_CRG54 bit[1].                                                         |
| vo_bus_cken   | VO bus clock status. This signal can be controlled by configuring PERI_CRG54 bit[0].                                                     |

### 3.3.3.26 Configuring the VPSS Clock Frequency

Table 3-28 describes frequency configurations of VPSS clocks.

**Table 3-28** Frequency configurations of VPSS clocks

| Signal       | Description                                                                          |
|--------------|--------------------------------------------------------------------------------------|
| vpss_clk_sel | VPSS clock select. This signal can be controlled by configuring PERI_CRG60 bit[9:8]. |
| vpss_cken    | VPSS clock status. This signal can be controlled by configuring PERI_CRG60 bit[0].   |

### 3.3.3.27 Configuring the PVR-1 Clock Frequency

Table 3-29 describes frequency configurations of PVR-1 clocks.



**Table 3-29** Frequency configurations of PVR-1 clocks

| Signal         | Description                                                                                                   |
|----------------|---------------------------------------------------------------------------------------------------------------|
| pvr_tsi2_pctrl | PVR TSI2 clock phase select. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[16]. |
| pvr_tsi1_pctrl | PVR TSI1 clock phase select. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[15]. |
| pvr_tsi2_cken  | PVR TSI2 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[4].        |
| pvr_tsi1_cken  | PVR TSI1 clock status. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[3].        |
| pvr_27m_cken   | PVR 27 MHz clock status. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[2].      |
| pvr_dmx_cken   | PVR DMX clock status. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[1].         |
| pvr_bus_cken   | PVR bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG63</a> bit[0].         |

### 3.3.3.28 Configuring the PVR-2 Clock Frequency

[Table 3-30](#) describes the frequency configuration of the PVR-2 clock.

**Table 3-30** Frequency configuration of the PVR-2 clock

| Signal          | Description                                                                                             |
|-----------------|---------------------------------------------------------------------------------------------------------|
| pvr_dmx_clk_sel | PVR DMX clock select. This signal can be controlled by configuring <a href="#">PERI_CRG64</a> bit[3:2]. |

### 3.3.3.29 Configuring the HDMITX CTRL Clock Frequency

[Table 3-31](#) describes frequency configurations of HDMI TX CTRL clocks.

**Table 3-31** Frequency configurations of HDMI TX CTRL clocks

| Signal               | Description                                                                                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------|
| hdmitx_ctrl_as_cken  | HDMITX CTRL AS clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[5].  |
| hdmitx_ctrl_os_cken  | HDMITX CTRL OS clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[4].  |
| hdmitx_ctrl_mhl_cken | HDMITX CTRL MHL clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[3]. |
| hdmitx_ctrl_id_cken  | HDMITX CTRL ID clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[2].  |



| Signal               | Description                                                                                                   |
|----------------------|---------------------------------------------------------------------------------------------------------------|
| hdmitx_ctrl_cec_cken | HDMITX CTRL CEC clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[1]. |
| hdmitx_ctrl_bus_cken | HDMITX CTRL bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG67</a> bit[0]. |

### 3.3.3.30 Configuring the HDMITX PHY Clock Frequency

[Table 3-32](#) describes the frequency configuration of the HDMI TX PHY clock.

**Table 3-32** Frequency configuration of the HDMI TX PHY clock

| Signal              | Description                                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------|
| hdmitx_phy_bus_cken | HDMITX PHY bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG68</a> bit[0]. |

### 3.3.3.31 Configuring the ADAC Clock Frequency

[Table 3-33](#) describes the frequency configuration of the ADAC clock.

**Table 3-33** Frequency configuration of the ADAC clock

| Signal    | Description                                                                                            |
|-----------|--------------------------------------------------------------------------------------------------------|
| adac_cken | ADAC bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG69</a> bit[0]. |

### 3.3.3.32 Configuring the AIAO Clock Frequency

[Table 3-34](#) describes frequency configurations of AIAO clocks.

**Table 3-34** Frequency configurations of AIAO clocks

| Signal        | Description                                                                                                   |
|---------------|---------------------------------------------------------------------------------------------------------------|
| aiao_mclk_sel | MCLK clock source select. This signal can be controlled by configuring <a href="#">PERI_CRG70</a> bit[21:20]. |
| aiao_cken     | AIAO clock status. This signal can be controlled by configuring <a href="#">PERI_CRG70</a> bit[0].            |

### 3.3.3.33 Configuring the VDAC Clock Frequency

[Table 3-35](#) describes frequency configurations of VDAC clocks.



**Table 3-35** Frequency configurations of the VDAC clocks

| Signal           | Description                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------|
| vdac_c_clk_pctrl | VDAC C clock phase select. This signal can be controlled by configuring <a href="#">PERI_CRG71</a> bit[16]. |
| vdac_chop_cken   | VDAC CHOP clock status. This signal can be controlled by configuring <a href="#">PERI_CRG71</a> bit[0].     |

### 3.3.3.34 Configuring the FE PHY Clock Frequency

[Table 3-36](#) describes frequency configurations of FE PHY clocks.

**Table 3-36** Frequency configurations of FE PHY clocks

| Signal         | Description                                                                                          |
|----------------|------------------------------------------------------------------------------------------------------|
| fephys_clk_sel | FE PHY clock select. This signal can be controlled by configuring <a href="#">PERI_CRG72</a> bit[8]. |
| fephys_cken    | FE PHY clock status. This signal can be controlled by configuring <a href="#">PERI_CRG72</a> bit[0]. |

### 3.3.3.35 Configuring the GPU Clock Frequency

[Table 3-37](#) describes the frequency configuration of the GPU clock.

**Table 3-37** Frequency configuration of the GPU clock

| Signal               | Description                                                                                                |
|----------------------|------------------------------------------------------------------------------------------------------------|
| gpu_freq_sel_cfg_crg | GPU clock source select. This signal can be controlled by configuring <a href="#">PERI_CRG73</a> bit[2:0]. |

### 3.3.3.36 Configuring the DDR Clock Frequency

[Table 3-38](#) describes the frequency configuration of the DDR clock.

**Table 3-38** Frequency configuration of the DDR clock

| Signal               | Description                                                                                                |
|----------------------|------------------------------------------------------------------------------------------------------------|
| ddr_freq_sel_cfg_crg | DDR clock source select. This signal can be controlled by configuring <a href="#">PERI_CRG74</a> bit[2:0]. |

### 3.3.3.37 Configuring the WDG Clock Frequency

[Table 3-39](#) describes frequency configurations of WDG clocks.



**Table 3-39** Frequency configurations of WDG clocks

| Signal    | Description                                                                                       |
|-----------|---------------------------------------------------------------------------------------------------|
| wdg0_cken | WDG clock status. This signal can be controlled by configuring <a href="#">PERI_CRG94</a> bit[0]. |

### 3.3.3.38 Configuring the USB2 PHY1 Clock Frequency

[Table 3-40](#) describes frequency configurations of USB2 PHY1 clocks.

**Table 3-40** Frequency configurations of USB2 PHY1 clocks

| Signal               | Description                                                                                                      |
|----------------------|------------------------------------------------------------------------------------------------------------------|
| usb2_phy1_refclk_sel | USB2 PHY1 REFCLK clock select. This signal can be controlled by configuring <a href="#">PERI_CRG100</a> bit[16]. |
| usb2_phy1_ref_cken   | USB2 PHY1 REFCLK clock status. This signal can be controlled by configuring <a href="#">PERI_CRG100</a> bit[0].  |

### 3.3.3.39 Configuring the USB3 PHY Clock Frequency

[Table 3-41](#) describes frequency configurations of USB3 PHY clocks.

**Table 3-41** Frequency configurations of USB3 PHY clocks

| Signal              | Description                                                                                                          |
|---------------------|----------------------------------------------------------------------------------------------------------------------|
| usb3_ref_ssp_en     | USB3 PHY super-speed clock status. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[10]. |
| usb3_ref_use_pad    | USB3 PHY reference clock select. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[9].    |
| usb3_phy_refclk_sel | USB3 PHY reference clock select. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[8].    |
| usb3_phy_ref_cken   | USB3 PHY reference clock status. This signal can be controlled by configuring <a href="#">PERI_CRG101</a> bit[0].    |

### 3.3.3.40 Configuring the USB2 CRTL1 Clock Frequency

[Table 3-42](#) describes frequency configurations of USB2 CTRL1 clocks.

**Table 3-42** Frequency configurations of USB2 CTRL1 clocks

| Signal           | Description                                                                                                     |
|------------------|-----------------------------------------------------------------------------------------------------------------|
| usb2_utmi0_cken1 | USB2 CTRL1 UTMIO clock status. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[5]. |



| Signal             | Description                                                                                                       |
|--------------------|-------------------------------------------------------------------------------------------------------------------|
| usb2_hst_phy_cken1 | USB2 CTRL1 HSTPHY clock status. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[4].  |
| usb2_ohci12m_cken1 | USB2 CTRL1 OHCI12M clock status. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[2]. |
| usb2_ohci48m_cken1 | USB2 CTRL1 OHCI48M clock status. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[1]. |
| usb2_bus_cken1     | USB2 CTRL1 bus clock status. This signal can be controlled by configuring <a href="#">PERI_CRG102</a> bit[0].     |

### 3.3.4 Register Summary

[Table 3-43](#) describes CRG registers.

**Table 3-43** Summary of CRG registers (base address: 0xF8A2\_2000)

| Offset Address | Register   | Description                                            | Page                 |
|----------------|------------|--------------------------------------------------------|----------------------|
| 0x0058         | PERI_CRG22 | SYS clock and soft reset control register              | <a href="#">3-25</a> |
| 0x0060         | PERI_CRG24 | NANDC clock and soft reset control register            | <a href="#">3-26</a> |
| 0x0064         | PERI_CRG25 | DDR clock and soft reset control register              | <a href="#">3-27</a> |
| 0x0068         | PERI_CRG26 | UART clock and soft reset control register             | <a href="#">3-28</a> |
| 0x006C         | PERI_CRG27 | I <sup>2</sup> C clock and soft reset control register | <a href="#">3-29</a> |
| 0x0070         | PERI_CRG28 | SSP clock and soft reset control register              | <a href="#">3-30</a> |
| 0x0074         | PERI_CRG29 | SCI clock and soft reset control register              | <a href="#">3-30</a> |
| 0x0078         | PERI_CRG30 | VDH clock and soft reset control register              | <a href="#">3-31</a> |
| 0x007C         | PERI_CRG31 | JPGD clock and soft reset control register             | <a href="#">3-32</a> |
| 0x0084         | PERI_CRG33 | PGD clock and soft reset control register              | <a href="#">3-33</a> |
| 0x0088         | PERI_CRG34 | BPD clock and soft reset control register              | <a href="#">3-33</a> |
| 0x008C         | PERI_CRG35 | VENC clock and soft reset control register             | <a href="#">3-34</a> |
| 0x0090         | PERI_CRG36 | JPGE clock and soft reset control register             | <a href="#">3-35</a> |
| 0x0094         | PERI_CRG37 | TDE clock and soft reset control register              | <a href="#">3-36</a> |
| 0x009C         | PERI_CRG39 | SDIO0 (AHB1) clock and soft reset control register     | <a href="#">3-37</a> |
| 0x00A0         | PERI_CRG40 | SDIO1 (AHB0) clock and soft reset control register     | <a href="#">3-38</a> |



| Offset Address | Register   | Description                                       | Page                 |
|----------------|------------|---------------------------------------------------|----------------------|
| 0x00A4         | PERI_CRG41 | DMA clock and soft reset control register         | <a href="#">3-40</a> |
| 0x00B0         | PERI_CRG44 | USB3 CTRL clock and soft reset control register   | <a href="#">3-41</a> |
| 0x00B8         | PERI_CRG46 | USB2 CTRL0 clock and soft reset control register  | <a href="#">3-42</a> |
| 0x00BC         | PERI_CRG47 | USB2 PHY0 clock and soft reset control register   | <a href="#">3-44</a> |
| 0x00C0         | PERI_CRG48 | CA clock and soft reset control register          | <a href="#">3-45</a> |
| 0x00C4         | PERI_CRG49 | SHA clock and soft reset control register         | <a href="#">3-45</a> |
| 0x00C8         | PERI_CRG50 | PMC clock and soft reset control register         | <a href="#">3-46</a> |
| 0x00CC         | PERI_CRG51 | ETH clock and soft reset control register         | <a href="#">3-47</a> |
| 0x00D4         | PERI_CRG53 | GPU clock and soft reset control register         | <a href="#">3-48</a> |
| 0x00D8         | PERI_CRG54 | VDP clock and soft reset control register         | <a href="#">3-48</a> |
| 0x00F0         | PERI_CRG60 | VPSS clock and soft reset control register.       | <a href="#">3-50</a> |
| 0x00FC         | PERI_CRG63 | PVR-1 clock and soft reset control register       | <a href="#">3-52</a> |
| 0x0100         | PERI_CRG64 | PVR-2 clock and soft reset control register       | <a href="#">3-53</a> |
| 0x010C         | PERI_CRG67 | HDMITX_CTRL clock and soft reset control register | <a href="#">3-54</a> |
| 0x0110         | PERI_CRG68 | HDMITX_PHY clock and soft reset control register  | <a href="#">3-55</a> |
| 0x0114         | PERI_CRG69 | ADAC clock and soft reset control register        | <a href="#">3-56</a> |
| 0x0118         | PERI_CRG70 | AIAO clock and soft reset control register        | <a href="#">3-56</a> |
| 0x011C         | PERI_CRG71 | VDAC clock and soft reset control register        | <a href="#">3-57</a> |
| 0x0120         | PERI_CRG72 | FE PHY clock and soft reset control register      | <a href="#">3-58</a> |
| 0x0124         | PERI_CRG73 | GPU_LP clock and soft reset control register      | <a href="#">3-59</a> |
| 0x0128         | PERI_CRG74 | DDR_LP clock and soft reset control register      | <a href="#">3-60</a> |
| 0x0154         | PERI_CRG85 | SW_READBACK register                              | <a href="#">3-61</a> |
| 0x0168         | PERI_CRG90 | Output reset control register                     | <a href="#">3-62</a> |
| 0x016C         | PERI_CRG91 | USB_FREECLK_DEC control register                  | <a href="#">3-63</a> |
| 0x0174         | PERI_CRG93 | VDH_RST_READBACK register                         | <a href="#">3-63</a> |



| Offset Address | Register    | Description                                      | Page                 |
|----------------|-------------|--------------------------------------------------|----------------------|
| 0x0178         | PERI_CRG94  | WDG clock and soft reset control register        | <a href="#">3-64</a> |
| 0x0190         | PERI_CRG100 | USB2 PHY2 clock and soft reset control register  | <a href="#">3-66</a> |
| 0x0194         | PERI_CRG101 | USB3 PHY clock and soft reset control register   | <a href="#">3-67</a> |
| 0x0198         | PERI_CRG102 | USB2 CTRL2 clock and soft reset control register | <a href="#">3-68</a> |

### 3.3.5 Register Description

#### PERI\_CRG22

PERI\_CRG22 is a SYS clock and soft reset control register.

|         | Offset Address                                                                                                                                                                                        | Register Name    | Total Reset Value                                                                                                |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|------------------|--------------|--------------|----------|--------------|--------------|------------------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0                                                                                                   | PERI_CRG22       | 0x0000_0000                                                                                                      |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
| Name    | reserved                                                                                                                                                                                              |                  |                                                                                                                  |  |  |  |  |  |  |  |  |  | core_bus_clk_div | mde3_clk_sel | mde2_clk_sel | reserved | mde1_clk_sel | mde0_clk_sel | core_bus_clk_sel |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                  |                                                                                                                  |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
| Bits    | Access                                                                                                                                                                                                | Name             | Description                                                                                                      |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
| [31:14] | RW                                                                                                                                                                                                    | reserved         | Reserved                                                                                                         |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
| [13:12] | RW                                                                                                                                                                                                    | core_bus_clk_div | Core bus clock frequency divider<br>00: divided by 1<br>01: divided by 2<br>10: divided by 3<br>11: divided by 4 |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |
| [11:10] | RW                                                                                                                                                                                                    | mde3_clk_sel     | Media3 bus clock select<br>00: 24 MHz<br>01: 300 MHz<br>10: 400 MHz<br>11: 345.6 MHz                             |  |  |  |  |  |  |  |  |  |                  |              |              |          |              |              |                  |



|       |    |                  |                                                                                      |
|-------|----|------------------|--------------------------------------------------------------------------------------|
| [9:8] | RW | mde2_clk_sel     | Media2 bus clock select<br>00: 24 MHz<br>01: 300 MHz<br>10: 400 MHz<br>11: 345.6 MHz |
| [7:6] | RW | reserved         | Reserved                                                                             |
| [5:4] | RW | mde1_clk_sel     | Media1 bus clock select<br>00: 24 MHz<br>01: 200 MHz<br>10: 250 MHz<br>11: reserved  |
| [3:2] | RW | mde0_clk_sel     | Media0 bus clock select<br>00: 24 MHz<br>01: 300 MHz<br>10: 400 MHz<br>11: 345.6 MHz |
| [1:0] | RW | core_bus_clk_sel | Core bus clock select<br>00: 24 MHz<br>01: 200 MHz<br>10: 100 MHz<br>11: reserved    |

## PERI\_CRG24

PERI\_CRG24 is a NANDC clock and soft reset control register.

| Offset Address |             | Register Name |             | Total Reset Value |             |           |            |          |
|----------------|-------------|---------------|-------------|-------------------|-------------|-----------|------------|----------|
| Bit            | 31 30 29 28 | 27 26 25 24   | 23 22 21 20 | 19 18 17 16       | 15 14 13 12 | 11 10 9 8 | 7 6 5 4    | 3 2 1 0  |
| Name           | reserved    |               |             |                   |             |           | nf_clk_sel | reserved |
| Reset          | 0 0 0 0     | 0 0 0 0       | 0 0 0 0     | 0 0 0 0           | 0 0 0 0     | 0 0 0 0   | 0 0 0 0    | 0 0 0 1  |
| Bits           | Access      | Name          | Description |                   |             |           |            |          |
| [31:11]        | RW          | reserved      | Reserved    |                   |             |           |            |          |



|        |    |             |                                                                       |
|--------|----|-------------|-----------------------------------------------------------------------|
| [10:8] | RW | nf_clk_sel  | NANDC clock select<br>000: 24 MHz<br>100: 200 MHz<br>Others: reserved |
| [7:5]  | RW | reserved    | Reserved                                                              |
| [4]    | RW | nf_srst_req | NANDC soft reset<br>0: not reset<br>1: reset                          |
| [3:1]  | RW | reserved    | Reserved                                                              |
| [0]    | RW | nf_cken     | NANDC clock gating<br>0: disabled<br>1: enabled                       |

## PERI\_CRG25

PERI\_CRG25 is a DDR clock and soft reset control register.

|         | Offset Address<br>0x0064 |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG25 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_100F |           |          |               |               |                 |          |           |             |            |          |
|---------|--------------------------|---------------|----|----|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|-----------|----------|---------------|---------------|-----------------|----------|-----------|-------------|------------|----------|
| Bit     | 31                       | 30            | 29 | 28 | 27                                             | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6         | 5        | 4             | 3             | 2               | 1        | 0         |             |            |          |
| Name    | reserved                 |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  | ddrt_cken | reserved | ddrt_srst_req | ddrc_srst_req | hipack_srst_req | reserved | ddrc_cken | hipack_cken | ddphy_cken | drr_cken |
| Reset   | 0                        | 0             | 0  | 0  | 0                                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 1  | 0  | 0  | 0 | 0 | 0                                | 0         | 0        | 0             | 1             | 1               | 1        | 1         |             |            |          |
| Bits    | Access                   | Name          |    |    | Description                                    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |           |          |               |               |                 |          |           |             |            |          |
| [31:13] | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |           |          |               |               |                 |          |           |             |            |          |
| [12]    | RW                       | ddrt_cken     |    |    | DDRT clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |           |          |               |               |                 |          |           |             |            |          |
| [11]    | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |           |          |               |               |                 |          |           |             |            |          |
| [10]    | RW                       | ddrt_srst_req |    |    | DDRT soft reset<br>0: not reset<br>1: reset    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |           |          |               |               |                 |          |           |             |            |          |



|       |    |                 |                                                       |
|-------|----|-----------------|-------------------------------------------------------|
| [9]   | RW | ddrc_srst_req   | DDRC prst soft reset<br>0: not reset<br>1: reset      |
| [8]   | RW | hipack_srst_req | HIPACK prst soft reset<br>0: not reset<br>1: reset    |
| [7:4] | RW | reserved        | Reserved                                              |
| [3]   | RW | ddrc_cken       | DDRC pclk clock gating<br>0: disabled<br>1: enabled   |
| [2]   | RW | hipack_cken     | HIPACK pclk clock gating<br>0: disabled<br>1: enabled |
| [1]   | RW | ddrphy_cken     | DDR PHY clock gating<br>0: disabled<br>1: enabled     |
| [0]   | RW | ddr_cken        | DDRC clock gating<br>0: disabled<br>1: enabled        |

## PERI\_CRG26

PERI\_CRG26 is a UART clock and soft reset control register.

|        | Offset Address<br>0x0068 |          |    |    |             |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG26 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0011 |                |            |          |                |            |   |   |
|--------|--------------------------|----------|----|----|-------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|----------------|------------|----------|----------------|------------|---|---|
| Bit    | 31                       | 30       | 29 | 28 | 27          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6              | 5          | 4        | 3              | 2          | 1 | 0 |
| Name   | reserved                 |          |    |    |             |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  | uart2_srst_req | uart2_cken | reserved | uart1_srst_req | uart1_cken |   |   |
| Reset  | 0                        | 0        | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1                                | 0              | 0          | 0        | 1              |            |   |   |
| Bits   | Access                   | Name     |    |    | Description |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |                |            |          |                |            |   |   |
| [31:6] | RW                       | reserved |    |    | Reserved    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |                |            |          |                |            |   |   |



|       |    |                |                                                 |
|-------|----|----------------|-------------------------------------------------|
| [5]   | RW | uart2_srst_req | UART2 soft reset<br>0: not reset<br>1: reset    |
| [4]   | RW | uart2_cken     | UART2 clock gating<br>0: disabled<br>1: enabled |
| [3:2] | RW | reserved       | Reserved                                        |
| [1]   | RW | uart1_srst_req | UART1 soft reset<br>0: not reset<br>1: reset    |
| [0]   | RW | uart1_cken     | UART1 clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG27

PERI\_CRG27 is an I<sup>2</sup>C clock and soft reset control register.

|         | Offset Address<br>0x006C |               |    |                                                             |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG27 |           |          |               |           |          |               |           | Total Reset Value<br>0x0000_1110 |   |   |   |   |   |   |   |
|---------|--------------------------|---------------|----|-------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|-----------|----------|---------------|-----------|----------|---------------|-----------|----------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                       | 30            | 29 | 28                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14        | 13       | 12            | 11        | 10       | 9             | 8         | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 |               |    |                                                             |    |    |    |    |    |    |    |    |    |    |    |    | i2c2_srst_req               | i2c2_cken | reserved | i2c1_srst_req | i2c1_cken | reserved | i2c0_srst_req | i2c0_cken | reserved                         |   |   |   |   |   |   |   |
| Reset   | 0                        | 0             | 0  | 0                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0         | 1        | 0             | 0         | 0        | 1             | 0         | 0                                | 0 | 1 | 0 | 0 | 0 | 0 |   |
| Bits    | Access                   | Name          |    | Description                                                 |    |    |    |    |    |    |    |    |    |    |    |    |                             |           |          |               |           |          |               |           |                                  |   |   |   |   |   |   |   |
| [31:14] | RW                       | reserved      |    | Reserved                                                    |    |    |    |    |    |    |    |    |    |    |    |    |                             |           |          |               |           |          |               |           |                                  |   |   |   |   |   |   |   |
| [13]    | RW                       | i2c2_srst_req |    | I <sup>2</sup> C2 soft reset<br>0: not reset<br>1: reset    |    |    |    |    |    |    |    |    |    |    |    |    |                             |           |          |               |           |          |               |           |                                  |   |   |   |   |   |   |   |
| [12]    | RW                       | i2c2_cken     |    | I <sup>2</sup> C2 clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |    |                             |           |          |               |           |          |               |           |                                  |   |   |   |   |   |   |   |
| [11:10] | RW                       | reserved      |    | Reserved                                                    |    |    |    |    |    |    |    |    |    |    |    |    |                             |           |          |               |           |          |               |           |                                  |   |   |   |   |   |   |   |



|       |    |               |                                                             |
|-------|----|---------------|-------------------------------------------------------------|
| [9]   | RW | i2c1_srst_req | I <sup>2</sup> C1 soft reset<br>0: not reset<br>1: reset    |
| [8]   | RW | i2c1_cken     | I <sup>2</sup> C1 clock gating<br>0: disabled<br>1: enabled |
| [7:6] | RW | reserved      | Reserved                                                    |
| [5]   | RW | i2c0_srst_req | I <sup>2</sup> C0 soft reset<br>0: not reset<br>1: reset    |
| [4]   | RW | i2c0_cken     | I <sup>2</sup> C0 clock gating<br>0: disabled<br>1: enabled |
| [3:0] | RW | reserved      | Reserved                                                    |

## PERI\_CRG28

PERI\_CRG28 is an SSP clock and soft reset control register.

|        | Offset Address<br>0x0070 |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG28 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0001 |   |   |   |               |           |   |   |
|--------|--------------------------|---------------|----|----|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---------------|-----------|---|---|
| Bit    | 31                       | 30            | 29 | 28 | 27                                             | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3             | 2         | 1 | 0 |
| Name   | reserved                 |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   | ssp0_srst_req | ssp0_cken |   |   |
| Reset  | 0                        | 0             | 0  | 0  | 0                                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0             | 1         |   |   |
| Bits   | Access                   | Name          |    |    | Description                                    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |               |           |   |   |
| [31:2] | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |               |           |   |   |
| [1]    | RW                       | ssp0_srst_req |    |    | SSP0 soft reset<br>0: not reset<br>1: reset    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |               |           |   |   |
| [0]    | RW                       | ssp0_cken     |    |    | SSP0 clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |               |           |   |   |



## PERI\_CRG29

PERI\_CRG29 is an SCI clock and soft reset control register.

|        | Offset Address                                                                                                                                                                    | Register Name | Total Reset Value                              |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|---------------|-----------|
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0                                                                               | PERI_CRG29    | 0x0000_0001                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
| Name   | reserved                                                                                                                                                                          |               |                                                |  |  |  |  |  |  |  |  |  |  |  |  |  | sci0_srst_req | sci0_cken |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 1 |               |                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
| Bits   | Access                                                                                                                                                                            | Name          | Description                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
| [31:2] | RW                                                                                                                                                                                | reserved      | Reserved                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
| [1]    | RW                                                                                                                                                                                | sci0_srst_req | SCI0 soft rest<br>0: not reset<br>1: reset     |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |
| [0]    | RW                                                                                                                                                                                | sci0_cken     | SCI0 clock gating<br>0: disabled<br>1: enabled |  |  |  |  |  |  |  |  |  |  |  |  |  |               |           |

## PERI\_CRG30

PERI\_CRG30 is a VDH clock and soft reset control register.



| Offset Address |          |                  |                                                                                                                                                                                 |    |    |    |    |    |    |    |    | Register Name |               |                |    |    |    |          |             |          |                  |                  |                  | Total Reset Value |             |          |   |   |   |   |   |   |  |  |  |
|----------------|----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|---------------|---------------|----------------|----|----|----|----------|-------------|----------|------------------|------------------|------------------|-------------------|-------------|----------|---|---|---|---|---|---|--|--|--|
| 0x0078         |          |                  |                                                                                                                                                                                 |    |    |    |    |    |    |    |    | PERI_CRG30    |               |                |    |    |    |          |             |          |                  |                  |                  | 0x0000_0003       |             |          |   |   |   |   |   |   |  |  |  |
| Bit            | 31       | 30               | 29                                                                                                                                                                              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19            | 18             | 17 | 16 | 15 | 14       | 13          | 12       | 11               | 10               | 9                | 8                 | 7           | 6        | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | reserved |                  |                                                                                                                                                                                 |    |    |    |    |    |    |    |    |               | vdhclk_loaden | vdhclk_skipcfg |    |    |    | reserved | vdh_clk_sel | reserved | vdh_mfd_srst_req | vdh_scd_srst_req | vdh_all_srst_req | reserved          | vdhdsp_cken | vdh_cken |   |   |   |   |   |   |  |  |  |
| Reset          | 0        | 0                | 0                                                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             | 0              | 0  | 0  | 0  | 0        | 0           | 0        | 0                | 0                | 0                | 0                 | 0           | 0        | 0 | 1 | 1 |   |   |   |  |  |  |
| Bits           | Access   | Name             | Description                                                                                                                                                                     |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [31:18]        | RW       | reserved         | Reserved                                                                                                                                                                        |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [17]           | RW       | vdhclk_loaden    | VDH pulse filter/frequency scale enable<br>0: disabled<br>1: enabled                                                                                                            |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [16:12]        | RW       | vdhclk_skipcfg   | VDH pulse filter/frequency scale<br>0x0: No pulse is filtered out.<br>0x1: One pulse is filtered out.<br>0x2: Two pulses are filtered out.<br>The rule applies to other values. |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [11:10]        | RW       | reserved         | Reserved                                                                                                                                                                        |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [9:8]          | RW       | vdh_clk_sel      | VDH clock select<br>00: 300 MHz<br>01: 288 MHz<br>10: 400 MHz<br>11: 345.6 MHz                                                                                                  |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [7]            | RW       | reserved         | Reserved                                                                                                                                                                        |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [6]            | RW       | vdh_mfd_srst_req | MFD soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [5]            | RW       | vdh_scd_srst_req | SCD soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [4]            | RW       | vdh_all_srst_req | VDH soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |
| [3:2]          | RW       | reserved         | Reserved                                                                                                                                                                        |    |    |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |                  |                  |                  |                   |             |          |   |   |   |   |   |   |  |  |  |



|     |    |             |                                                  |
|-----|----|-------------|--------------------------------------------------|
| [1] | RW | vdhdsp_cken | VDHDSP clock gating<br>0: disabled<br>1: enabled |
| [0] | RW | vdh_cken    | VDH clock gating<br>0: disabled<br>1: enabled    |

## PERI\_CRG31

PERI\_CRG31 is a JPGD clock and soft reset control register.

|        | Offset Address<br>0x007C |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG31 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0001 |              |          |               |          |           |   |   |
|--------|--------------------------|---------------|----|----|------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|--------------|----------|---------------|----------|-----------|---|---|
| Bit    | 31                       | 30            | 29 | 28 | 27                                             | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6            | 5        | 4             | 3        | 2         | 1 | 0 |
| Name   | reserved                 |               |    |    |                                                |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  | jpgd_clk_sel | reserved | jpgd_srst_req | reserved | jpgd_cken |   |   |
| Reset  | 0                        | 0             | 0  | 0  | 0                                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0            | 0        | 0             | 0        | 0         | 1 |   |
| Bits   | Access                   | Name          |    |    | Description                                    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [31:9] | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [8]    | RW                       | jpgd_clk_sel  |    |    | JPGD clock select<br>0: 200 MHz<br>1: 150 MHz  |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [7:5]  | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [4]    | RW                       | jpgd_srst_req |    |    | JPGD soft reset<br>0: not reset<br>1: reset    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [3:1]  | RW                       | reserved      |    |    | Reserved                                       |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |
| [0]    | RW                       | jpgd_cken     |    |    | JPGD clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |              |          |               |          |           |   |   |

## PERI\_CRG33

PERI\_CRG33 is a PGD clock and soft reset control register.



PERI\_CRG34

**PERI\_CRG34** is a BPD clock and soft reset control register.

| Offset Address |          |          |    |    |    |             |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |              |          |          |   |   |   |   |
|----------------|----------|----------|----|----|----|-------------|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|--------------|----------|----------|---|---|---|---|
| 0x0088         |          |          |    |    |    |             |    | PERI_CRG34    |    |    |    |    |    |    |    | 0x0000_0001       |    |    |    |    |    |    |   |   |   |              |          |          |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26          | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6            | 5        | 4        | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |    |             |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   | bpd_srst_req | reserved | bpd_cken |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0           | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0            | 0        | 0        | 0 | 1 |   |   |
| Bits           | Access   | Name     |    |    |    | Description |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |          |          |   |   |   |   |
| [31:5]         | RW       | reserved |    |    |    | Reserved    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |          |          |   |   |   |   |



|       |    |              |                                               |
|-------|----|--------------|-----------------------------------------------|
| [4]   | RW | bpd_srst_req | BPD soft reset<br>0: not reset<br>1: reset    |
| [3:1] | RW | reserved     | Reserved                                      |
| [0]   | RW | bpd_cken     | BPD clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG35

PERI\_CRG35 is a VENC clock and soft reset control register.

|        | Offset Address<br>0x008C |               |    |                                                                 |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG35 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0001 |          |               |          |           |   |   |   |
|--------|--------------------------|---------------|----|-----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|----------|---------------|----------|-----------|---|---|---|
| Bit    | 31                       | 30            | 29 | 28                                                              | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6        | 5             | 4        | 3         | 2 | 1 | 0 |
| Name   | reserved                 |               |    |                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   | venc_clk_sel                     | reserved | venc_srst_req | reserved | venc_cken |   |   |   |
| Reset  | 0                        | 0             | 0  | 0                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0        | 0             | 0        | 0         | 1 |   |   |
| Bits   | Access                   | Name          |    | Description                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [31:9] | RW                       | reserved      |    | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [8:7]  | RW                       | venc_clk_sel  |    | VENC clock select<br>00: 200 MHz<br>10: 150 MHz<br>X1: reserved |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [6:5]  | RW                       | reserved      |    | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [4]    | RW                       | venc_srst_req |    | VENC soft reset<br>0: not reset<br>1: reset                     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [3:1]  | RW                       | reserved      |    | Reserved                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |
| [0]    | RW                       | venc_cken     |    | VENC clock gating<br>0: disabled<br>1: enabled                  |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |          |               |          |           |   |   |   |



## PERI\_CRG36

PERI\_CRG36 is a JPGE clock and soft reset control register.

|        | Offset Address                                                                                      | Register Name | Total Reset Value                              |  |  |  |  |  |  |  |  |  |               |          |           |
|--------|-----------------------------------------------------------------------------------------------------|---------------|------------------------------------------------|--|--|--|--|--|--|--|--|--|---------------|----------|-----------|
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | PERI_CRG36    | 0x0000_0001                                    |  |  |  |  |  |  |  |  |  |               |          |           |
| Name   | reserved                                                                                            |               |                                                |  |  |  |  |  |  |  |  |  | jpge_srst_req | reserved | jpge_cken |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 1                       |               |                                                |  |  |  |  |  |  |  |  |  |               |          |           |
| Bits   | Access                                                                                              | Name          | Description                                    |  |  |  |  |  |  |  |  |  |               |          |           |
| [31:5] | RW                                                                                                  | reserved      | Reserved                                       |  |  |  |  |  |  |  |  |  |               |          |           |
| [4]    | RW                                                                                                  | jpge_srst_req | JPGE soft reset<br>0: not reset<br>1: reset    |  |  |  |  |  |  |  |  |  |               |          |           |
| [3:1]  | RW                                                                                                  | reserved      | Reserved                                       |  |  |  |  |  |  |  |  |  |               |          |           |
| [0]    | RW                                                                                                  | jpge_cken     | JPGE clock gating<br>0: disabled<br>1: enabled |  |  |  |  |  |  |  |  |  |               |          |           |

## PERI\_CRG37

PERI\_CRG37 is a TDE clock and soft reset control register.



| Offset Address |          |                |    |    |                                                                                                                                                                                 |    |    |    |    |    |    | Register Name |               |                |    |    |    |          |             |          |              |          |          | Total Reset Value |          |          |          |          |          |          |          |   |  |  |  |
|----------------|----------|----------------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---------------|---------------|----------------|----|----|----|----------|-------------|----------|--------------|----------|----------|-------------------|----------|----------|----------|----------|----------|----------|----------|---|--|--|--|
| 0x0094         |          |                |    |    |                                                                                                                                                                                 |    |    |    |    |    |    | PERI_CRG37    |               |                |    |    |    |          |             |          |              |          |          | 0x0000_0001       |          |          |          |          |          |          |          |   |  |  |  |
| Bit            | 31       | 30             | 29 | 28 | 27                                                                                                                                                                              | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19            | 18             | 17 | 16 | 15 | 14       | 13          | 12       | 11           | 10       | 9        | 8                 | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0 |  |  |  |
| Name           | reserved |                |    |    |                                                                                                                                                                                 |    |    |    |    |    |    |               | tdeclk_loaden | tdeclk_skipcfg |    |    |    | reserved | tde_clk_sel | reserved | tde_srst_req | reserved | tde_cken | reserved          | reserved | reserved | reserved | reserved | reserved | reserved | reserved |   |  |  |  |
| Reset          | 0        | 0              | 0  | 0  | 0                                                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             | 0              | 0  | 0  | 0  | 0        | 0           | 0        | 0            | 0        | 0        | 0                 | 0        | 0        | 0        | 0        | 0        | 1        |          |   |  |  |  |
| Bits           | Access   | Name           |    |    | Description                                                                                                                                                                     |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [31:18]        | RW       | reserved       |    |    | Reserved                                                                                                                                                                        |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [17]           | RW       | tdeclk_loaden  |    |    | TDE pulse filter/frequency scale enable<br>0: disabled<br>1: enabled                                                                                                            |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [16:12]        | RW       | tdeclk_skipcfg |    |    | TDE pulse filter/frequency scale<br>0x0: No pulse is filtered out.<br>0x1: One pulse is filtered out.<br>0x2: Two pulses are filtered out.<br>The rule applies to other values. |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [11:10]        | RW       | reserved       |    |    | Reserved                                                                                                                                                                        |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [9:8]          | RW       | tde_clk_sel    |    |    | TDE clock select<br>00: 400 MHz<br>01: 500 MHz<br>1X: 432 MHz                                                                                                                   |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [7:5]          | RW       | reserved       |    |    | Reserved                                                                                                                                                                        |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [4]            | RW       | tde_srst_req   |    |    | TDE soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [3:1]          | RW       | reserved       |    |    | Reserved                                                                                                                                                                        |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |
| [0]            | RW       | tde_cken       |    |    | TDE clock gating<br>0: disabled<br>1: enabled                                                                                                                                   |    |    |    |    |    |    |               |               |                |    |    |    |          |             |          |              |          |          |                   |          |          |          |          |          |          |          |   |  |  |  |

## PERI\_CRG39

PERI\_CRG39 is an SDIO0 (AHB1) clock and soft reset control register.



| Offset Address |          |                  |    |                                                                                                                                             |    |    |    |    |    |    |    | Register Name |                |                  |          |                  |          |               |          |                |          |            |                | Total Reset Value |   |   |   |   |   |   |   |   |  |  |  |
|----------------|----------|------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|---------------|----------------|------------------|----------|------------------|----------|---------------|----------|----------------|----------|------------|----------------|-------------------|---|---|---|---|---|---|---|---|--|--|--|
| 0x009C         |          |                  |    |                                                                                                                                             |    |    |    |    |    |    |    | PERI_CRG39    |                |                  |          |                  |          |               |          |                |          |            |                | 0x0000_0003       |   |   |   |   |   |   |   |   |  |  |  |
| Bit            | 31       | 30               | 29 | 28                                                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19             | 18               | 17       | 16               | 15       | 14            | 13       | 12             | 11       | 10         | 9              | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | reserved |                  |    |                                                                                                                                             |    |    |    |    |    |    |    |               | sdio0_clk_mode | sdio0_drv_ps_sel | reserved | sdio0_sap_ps_sel | reserved | sdio0_clk_sel | reserved | sdio0_srst_req | reserved | sdio0_cken | sdio0_bus_cken |                   |   |   |   |   |   |   |   |   |  |  |  |
| Reset          | 0        | 0                | 0  | 0                                                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0              | 0                | 0        | 0                | 0        | 0             | 0        | 0              | 0        | 0          | 0              | 0                 | 0 | 0 | 1 | 1 |   |   |   |   |  |  |  |
| Bits           | Access   | Name             |    | Description                                                                                                                                 |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [31:20]        | RW       | reserved         |    | Reserved                                                                                                                                    |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [19]           | RW       | sdio0_clk_mode   |    | SDIO0 phase select<br>0: normal mode<br>1: DDR50 mode (reserved)                                                                            |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [18:16]        | RW       | sdio0_drv_ps_sel |    | Phase shift of the SDIO0 driver clock<br>000: 0°<br>001: 45°<br>010: 90°<br>011: 135°<br>100: 180°<br>101: 225°<br>110: 270°<br>111: 315°   |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [15]           | RW       | reserved         |    | Reserved                                                                                                                                    |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [14:12]        | RW       | sdio0_sap_ps_sel |    | Phase shift of the SDIO0 sampling clock<br>000: 0°<br>001: 45°<br>010: 90°<br>011: 135°<br>100: 180°<br>101: 225°<br>110: 270°<br>111: 315° |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |
| [11:10]        | RW       | reserved         |    | Reserved                                                                                                                                    |    |    |    |    |    |    |    |               |                |                  |          |                  |          |               |          |                |          |            |                |                   |   |   |   |   |   |   |   |   |  |  |  |



|       |    |                |                                                                             |
|-------|----|----------------|-----------------------------------------------------------------------------|
| [9:8] | RW | sdio0_clk_sel  | SDIO0 clock select<br>00: 75 MHz<br>01: 100 MHz<br>10: 50 MHz<br>11: 25 MHz |
| [7:5] | RW | reserved       | Reserved                                                                    |
| [4]   | RW | sdio0_srst_req | SDIO0 soft reset<br>0: not reset<br>1: reset                                |
| [3:2] | RW | reserved       | Reserved                                                                    |
| [1]   | RW | sdio0_cken     | SDIO0 clock gating<br>0: disabled<br>1: enabled                             |
| [0]   | RW | sdio0_bus_cken | SDIO0 bus clock gating<br>0: disabled<br>1: enabled                         |

## PERI\_CRG40

PERI\_CRG40 is an SDIO1 (AHB0) clock and soft reset control register.

|         | Offset Address<br>0x00A0 |                |    |    |                                                       |    |    |    |    |    | Register Name<br>PERI_CRG40 |                  |          |                  |          |               |          |                | Total Reset Value<br>0x0000_0003 |            |                |    |   |   |   |   |   |   |   |   |   |   |
|---------|--------------------------|----------------|----|----|-------------------------------------------------------|----|----|----|----|----|-----------------------------|------------------|----------|------------------|----------|---------------|----------|----------------|----------------------------------|------------|----------------|----|---|---|---|---|---|---|---|---|---|---|
| Bit     | 31                       | 30             | 29 | 28 | 27                                                    | 26 | 25 | 24 | 23 | 22 | 21                          | 20               | 19       | 18               | 17       | 16            | 15       | 14             | 13                               | 12         | 11             | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 |                |    |    |                                                       |    |    |    |    |    | sdio1_clk_mode              | sdio1_drv_ps_sel | reserved | sdio1_sap_ps_sel | reserved | sdio1_clk_sel | reserved | sdio1_srst_req | reserved                         | sdio1_cken | sdio1_bus_cken |    |   |   |   |   |   |   |   |   |   |   |
| Reset   | 0                        | 0              | 0  | 0  | 0                                                     | 0  | 0  | 0  | 0  | 0  | 0                           | 0                | 0        | 0                | 0        | 0             | 0        | 0              | 0                                | 0          | 0              | 0  | 0 | 0 | 0 | 0 | 0 | 1 | 1 |   |   |   |
| Bits    | Access                   | Name           |    |    | Description                                           |    |    |    |    |    |                             |                  |          |                  |          |               |          |                |                                  |            |                |    |   |   |   |   |   |   |   |   |   |   |
| [31:20] | RW                       | reserved       |    |    | Reserved                                              |    |    |    |    |    |                             |                  |          |                  |          |               |          |                |                                  |            |                |    |   |   |   |   |   |   |   |   |   |   |
| [19]    | RW                       | sdio1_clk_mode |    |    | SDIO1 phase select<br>0: normal mode<br>1: DDR50 mode |    |    |    |    |    |                             |                  |          |                  |          |               |          |                |                                  |            |                |    |   |   |   |   |   |   |   |   |   |   |



|         |    |                  |                                                                                                                                                                                                                                                                                                                             |
|---------|----|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [18:16] | RW | sdio1_drv_ps_sel | Phase shift of the SDIO1 driver clock (normal mode)<br>000: 0°<br>001: 45°<br>010: 90°<br>011: 135°<br>100: 180°<br>101: 225°<br>110: 270°<br>111: 315°<br>Phase shift of the SDIO1 driver clock (DDR50 mode)<br>000: 0°<br>001: 22.5°<br>010: 45°<br>011: 67.5°<br>100: 90°<br>101: 112.5°<br>110: 145°<br>111: 167.5°     |
| [15]    | RW | reserved         | Reserved                                                                                                                                                                                                                                                                                                                    |
| [14:12] | RW | sdio1_sap_ps_sel | Phase shift of the SDIO1 sampling clock (normal mode)<br>000: 0°<br>001: 45°<br>010: 90°<br>011: 135°<br>100: 180°<br>101: 225°<br>110: 270°<br>111: 315°<br>Phase shift of the SDIO1 sampling clock (DDR50 mode)<br>000: 0°<br>001: 22.5°<br>010: 45°<br>011: 67.5°<br>100: 90°<br>101: 112.5°<br>110: 145°<br>111: 167.5° |
| [11:10] | RW | reserved         | Reserved                                                                                                                                                                                                                                                                                                                    |



|       |    |                |                                                                             |
|-------|----|----------------|-----------------------------------------------------------------------------|
| [9:8] | RW | sdio1_clk_sel  | SDIO1 clock select<br>00: 75 MHz<br>01: 100 MHz<br>10: 50 MHz<br>11: 25 MHz |
| [7:5] | RW | reserved       | Reserved                                                                    |
| [4]   | RW | sdio1_srst_req | SDIO1 soft reset<br>0: not reset<br>1: reset                                |
| [3:2] | RW | reserved       | Reserved                                                                    |
| [1]   | RW | sdio1_cken     | SDIO1 clock gating<br>0: disabled<br>1: enabled                             |
| [0]   | RW | sdio1_bus_cken | SDIO1 bus clock gating<br>0: disabled<br>1: enabled                         |

## PERI\_CRG41

PERI\_CRG41 is a DMA clock and soft reset control register.

|        | Offset Address<br>0x00A4 |               |    |    |    |                                            |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG41 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0001 |   |   |   |   |               |          |           |  |
|--------|--------------------------|---------------|----|----|----|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---------------|----------|-----------|--|
| Bit    | 31                       | 30            | 29 | 28 | 27 | 26                                         | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2             | 1        | 0         |  |
| Name   | reserved                 |               |    |    |    |                                            |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   | dmac_srst_req | reserved | dmac_cken |  |
| Reset  | 0                        | 0             | 0  | 0  | 0  | 0                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0             | 1        |           |  |
| Bits   | Access                   | Name          |    |    |    | Description                                |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |               |          |           |  |
| [31:5] | RW                       | reserved      |    |    |    | Reserved                                   |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |               |          |           |  |
| [4]    | RW                       | dmac_srst_req |    |    |    | DMA soft reset<br>0: not reset<br>1: reset |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |               |          |           |  |
| [3:1]  | RW                       | reserved      |    |    |    | Reserved                                   |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |               |          |           |  |



|     |    |           |                                               |
|-----|----|-----------|-----------------------------------------------|
| [0] | RW | dmac_cken | DMA clock gating<br>0: disabled<br>1: enabled |
|-----|----|-----------|-----------------------------------------------|

## PERI\_CRG44

PERI\_CRG44 is a USB3 CTRL clock and soft reset control register.

|         | Offset Address<br>0x00B0 |                    |    |                                                              |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG44 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_13F7 |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
|---------|--------------------------|--------------------|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|---|---|--|--|--|--|--|
| Bit     | 31                       | 30                 | 29 | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |  |  |  |  |  |
| Name    | reserved                 |                    |    |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| Reset   | 0                        | 0                  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 0                                | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |  |  |  |  |  |
| Bits    | Access                   | Name               |    | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [31:13] | RW                       | reserved           |    | Reserved                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [12]    | RW                       | usb3_vcc_srst_req  |    | USB3 CTRL VCC soft reset<br>0: not reset<br>1: reset         |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [11:10] | RW                       | reserved           |    | Reserved                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [9]     | RW                       | usb3_pcs_ref_cken  |    | USB3 CTRL PCS_REF clock gating<br>0: disabled<br>1: enabled  |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [8]     | RW                       | usb3_pcs_rx_cken   |    | USB3 CTRL PCS RX clock gating<br>0: disabled<br>1: enabled   |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [7]     | RW                       | usb3_pcs_pclk_cken |    | USB3 CTRL PCS PCLK clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |
| [6]     | RW                       | usb3_bus_gm_cken   |    | USB3 CTRL GM bus clock gating<br>0: disabled<br>1: enabled   |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |   |   |  |  |  |  |  |



|     |    |                   |                                                               |
|-----|----|-------------------|---------------------------------------------------------------|
| [5] | RW | usb3_bus_gs_cken  | USB3 CTRL GS bus clock gating<br>0: disabled<br>1: enabled    |
| [4] | RW | usb3_utmi_cken    | USB3 CTRL UTMI clock gating<br>0: disabled<br>1: enabled      |
| [3] | RW | reserved          | Reserved                                                      |
| [2] | RW | usb3_suspend_cken | USB3 CTRL suspend clock gating<br>0: disabled<br>1: enabled   |
| [1] | RW | usb3_ref_cken     | USB3 CTRL reference clock gating<br>0: disabled<br>1: enabled |
| [0] | RW | usb3_bus_cken     | USB3 CTRL bus clock gating<br>0: disabled<br>1: enabled       |

## PERI\_CRG46

PERI\_CRG46 is a USB2 CTRL0 clock and soft reset control register.

| Offset Address<br>0x00B8 |          |                |    |    |                                                                           |    |    |    |    |    |    | Register Name<br>PERI_CRG46 |                |          |                       |                       |          |                     |                     |                   |          |                 |                 | Total Reset Value<br>0x0013_707F |                    |                   |                   |               |   |   |   |   |  |  |  |  |
|--------------------------|----------|----------------|----|----|---------------------------------------------------------------------------|----|----|----|----|----|----|-----------------------------|----------------|----------|-----------------------|-----------------------|----------|---------------------|---------------------|-------------------|----------|-----------------|-----------------|----------------------------------|--------------------|-------------------|-------------------|---------------|---|---|---|---|--|--|--|--|
| Bit                      | 31       | 30             | 29 | 28 | 27                                                                        | 26 | 25 | 24 | 23 | 22 | 21 | 20                          | 19             | 18       | 17                    | 16                    | 15       | 14                  | 13                  | 12                | 11       | 10              | 9               | 8                                | 7                  | 6                 | 5                 | 4             | 3 | 2 | 1 | 0 |  |  |  |  |
| Name                     | reserved |                |    |    |                                                                           |    |    |    |    |    |    |                             | usb2_clk48_sel | reserved | usb2_otg_phy_srst_req | usb2_hst_phy_srst_req | reserved | usb2_utmi1_srst_req | usb2_utmi0_srst_req | usb2_bus_srst_req | reserved | usb2_utmi1_cken | usb2_utmi0_cken | usb2_hst_phy_cken                | usb2_otg_utmi_cken | usb2_ohci12m_cken | usb2_ohci48m_cken | usb2_bus_cken |   |   |   |   |  |  |  |  |
| Reset                    | 0        | 0              | 0  | 0  | 0                                                                         | 0  | 0  | 0  | 0  | 0  | 0  | 1                           | 0              | 0        | 1                     | 1                     | 0        | 1                   | 1                   | 1                 | 0        | 0               | 0               | 0                                | 0                  | 1                 | 1                 | 1             | 1 | 1 | 1 |   |  |  |  |  |
| Bits                     | Access   | Name           |    |    | Description                                                               |    |    |    |    |    |    |                             |                |          |                       |                       |          |                     |                     |                   |          |                 |                 |                                  |                    |                   |                   |               |   |   |   |   |  |  |  |  |
| [31:21]                  | RW       | reserved       |    |    | Reserved                                                                  |    |    |    |    |    |    |                             |                |          |                       |                       |          |                     |                     |                   |          |                 |                 |                                  |                    |                   |                   |               |   |   |   |   |  |  |  |  |
| [20]                     | RW       | usb2_clk48_sel |    |    | USB2 CLK48 clock source select<br>0: provided by the CRG<br>1: PHY output |    |    |    |    |    |    |                             |                |          |                       |                       |          |                     |                     |                   |          |                 |                 |                                  |                    |                   |                   |               |   |   |   |   |  |  |  |  |
| [19:18]                  | RW       | reserved       |    |    | Reserved                                                                  |    |    |    |    |    |    |                             |                |          |                       |                       |          |                     |                     |                   |          |                 |                 |                                  |                    |                   |                   |               |   |   |   |   |  |  |  |  |



|        |    |                       |                                                              |
|--------|----|-----------------------|--------------------------------------------------------------|
| [17]   | RW | usb2_otg_phy_srst_req | USB2 CTRL OTG_PHY soft reset<br>0: not reset<br>1: reset     |
| [16]   | RW | usb2_hst_phy_srst_req | USB2 CTRL HST_PHY soft reset<br>0: not reset<br>1: reset     |
| [15]   | RW | reserved              | Reserved                                                     |
| [14]   | RW | usb2_utmi1_srst_req   | USB2 CTRL UTMI1 soft reset<br>0: not reset<br>1: reset       |
| [13]   | RW | usb2_utmi0_srst_req   | USB2 CTRL UTMI0 soft reset<br>0: not reset<br>1: reset       |
| [12]   | RW | usb2_bus_srst_req     | USB2 CTRL bus soft reset<br>0: not reset<br>1: reset         |
| [11:7] | RW | reserved              | Reserved                                                     |
| [6]    | RW | usb2_utmi1_cken       | USB2 CTRL UTMI1 clock gating<br>0: disabled<br>1: enabled    |
| [5]    | RW | usb2_utmi0_cken       | USB2 CTRL UTMI0 clock gating<br>0: disabled<br>1: enabled    |
| [4]    | RW | usb2_hst_phy_cken     | USB2 CTRL HST_PHY clock gating<br>0: disabled<br>1: enabled  |
| [3]    | RW | usb2_otg_utmi_cken    | USB2 CTRL OTG_UTMI clock gating<br>0: disabled<br>1: enabled |
| [2]    | RW | usb2_ocih12m_cken     | USB2 CTRL OHCI12M clock gating<br>0: disabled<br>1: enabled  |
| [1]    | RW | usb2_ocih48m_cken     | USB2 CTRL OHCI48M clock gating<br>0: disabled<br>1: enabled  |



|     |    |               |                                                         |
|-----|----|---------------|---------------------------------------------------------|
| [0] | RW | usb2_bus_cken | USB2 CTRL bus clock gating<br>0: disabled<br>1: enabled |
|-----|----|---------------|---------------------------------------------------------|

PERI\_CRG47

**PERI\_CRG47** is a USB2 PHY0 clock and soft reset control register.

| Offset Address |          |                     |    |                                                                                            |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
|----------------|----------|---------------------|----|--------------------------------------------------------------------------------------------|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|---------------------|----|----------|----|---------------------|----|----------|---|---------------------|---|-------------------|---|----------|---|---|---|
| 0x00BC         |          |                     |    |                                                                                            |    |    |    | PERI_CRG47    |    |    |    |    |    |    |    | 0x0000_0B01       |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| Bit            | 31       | 30                  | 29 | 28                                                                                         | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15                  | 14 | 13       | 12 | 11                  | 10 | 9        | 8 | 7                   | 6 | 5                 | 4 | 3        | 2 | 1 |   |
| Name           | reserved |                     |    |                                                                                            |    |    |    |               |    |    |    |    |    |    |    |                   | usb2_phy_refclk_sel |    | reserved |    | usb2_phy_srst_treq1 |    | reserved |   | usb2_phy_srst_treq0 |   | usb2_phy_srst_req |   | reserved |   |   |   |
| Reset          | 0        | 0                   | 0  | 0                                                                                          | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0                   | 0  | 0        | 0  | 1                   | 0  | 1        | 1 | 0                   | 0 | 0                 | 0 | 0        | 0 | 0 | 1 |
| Bits           | Access   | Name                |    | Description                                                                                |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [31:17]        | RW       | reserved            |    | Reserved                                                                                   |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [16]           | RW       | usb2_phy_refclk_sel |    | USB2 PHY reference clock select<br>0: crystal oscillator clock<br>1: 24 MHz internal clock |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [15:12]        | RW       | reserved            |    | Reserved                                                                                   |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [11]           | RW       | usb2_phy_srst_treq1 |    | USB2 PHY1 TPOR soft reset<br>0: not reset<br>1: reset                                      |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [10]           | RW       | reserved            |    | Reserved                                                                                   |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [9]            | RW       | usb2_phy_srst_treq0 |    | USB2 PHY0 TPOR soft reset<br>0: not reset<br>1: reset                                      |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [8]            | RW       | usb2_phy_srst_req   |    | USB2 PHY POR soft reset<br>0: not reset<br>1: reset                                        |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |
| [7:1]          | RW       | reserved            |    | Reserved                                                                                   |    |    |    |               |    |    |    |    |    |    |    |                   |                     |    |          |    |                     |    |          |   |                     |   |                   |   |          |   |   |   |



|     |    |                   |                                                              |
|-----|----|-------------------|--------------------------------------------------------------|
| [0] | RW | usb2_phy_ref_cken | USB2 PHY reference clock gating<br>0: disabled<br>1: enabled |
|-----|----|-------------------|--------------------------------------------------------------|

## PERI\_CRG48

PERI\_CRG48 is a CA clock and soft reset control register.

|         | Offset Address<br>0x00C0 |                |    |                                                    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG48 |          |              |                |          |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |  |  |  |
|---------|--------------------------|----------------|----|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----------|--------------|----------------|----------|----|---|---|----------------------------------|---|---|---|---|---|---|---|---|--|--|--|
| Bit     | 31                       | 30             | 29 | 28                                                 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14       | 13           | 12             | 11       | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |  |  |  |
| Name    | reserved                 |                |    |                                                    |    |    |    |    |    |    |    |    |    |    |    |    | ca_ci_clk_sel               | reserved | otp_srst_req | ca_ci_srst_req | reserved |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| Reset   | 0                        | 0              | 0  | 0                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0        | 0            | 0              | 0        | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |
| Bits    | Access                   | Name           |    | Description                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [31:13] | RW                       | reserved       |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [12]    | RW                       | ca_ci_clk_sel  |    | CA cipher clock select<br>0: 250 MHz<br>1: 150 MHz |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [11]    | RW                       | reserved       |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [10]    | RW                       | otp_srst_req   |    | OTP soft reset<br>0: not reset<br>1: reset         |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [9]     | RW                       | ca_ci_srst_req |    | CA cipher soft reset<br>0: not reset<br>1: reset   |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [8:0]   | RW                       | reserved       |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |              |                |          |    |   |   |                                  |   |   |   |   |   |   |   |   |  |  |  |

## PERI\_CRG49

PERI\_CRG49 is an SHA clock and soft reset control register.



PERI\_CRG50

**PERI\_CRG50** is a PMC clock and soft reset control register.

| Offset Address |          |          |    |    |             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |              |          |   |          |   |   |   |
|----------------|----------|----------|----|----|-------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|--------------|----------|---|----------|---|---|---|
| 0x00C8         |          |          |    |    |             |    |    | PERI_CRG50    |    |    |    |    |    |    |    | 0x0000_0011       |    |    |    |    |    |    |   |   |   |              |          |   |          |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6            | 5        | 4 | 3        | 2 | 1 | 0 |
| Name           | reserved |          |    |    |             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   | pmc_srst_req | reserved |   | pmc_cken |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 1            | 0        | 0 | 0        | 1 |   |   |
| Bits           | Access   | Name     |    |    | Description |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |          |   |          |   |   |   |
| [31:5]         | RW       | reserved |    |    | Reserved    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |          |   |          |   |   |   |



|       |    |              |                                               |
|-------|----|--------------|-----------------------------------------------|
| [4]   | RW | pmc_srst_req | PMC soft reset<br>0: not reset<br>1: reset    |
| [3:1] | RW | reserved     | Reserved                                      |
| [0]   | RW | pmc_cken     | PMC clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG51

PERI\_CRG51 is an ETH clock and soft reset control register.

|        | Offset Address<br>0x00CC |              |    |                                                                       |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG51 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0003 |   |   |   |            |             |          |              |   |  |  |
|--------|--------------------------|--------------|----|-----------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|------------|-------------|----------|--------------|---|--|--|
| Bit    | 31                       | 30           | 29 | 28                                                                    | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3          | 2           | 1        | 0            |   |  |  |
| Name   | reserved                 |              |    |                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   | hrst_eth_s | eth_clk_sel | eth_cken | eth_bus_cken |   |  |  |
| Reset  | 0                        | 0            | 0  | 0                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0          | 0           | 0        | 1            | 1 |  |  |
| Bits   | Access                   | Name         |    | Description                                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |
| [31:5] | RW                       | reserved     |    | Reserved                                                              |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |
| [4]    | RW                       | hrst_eth_s   |    | ETH reset (only when the ETH bus is idle)<br>0: not reset<br>1: reset |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |
| [3:2]  | RW                       | eth_clk_sel  |    | ETH working clock select<br>0: 54 MHz<br>1: 27 MHz<br>2: 83.3 MHz     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |
| [1]    | RW                       | eth_cken     |    | ETH working clock gating<br>0: disabled<br>1: enabled                 |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |
| [0]    | RW                       | eth_bus_cken |    | ETH bus clock gating<br>0: disabled<br>1: enabled                     |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |            |             |          |              |   |  |  |



## PERI\_CRG53

PERI\_CRG53 is a GPU clock and soft reset control register.

|         | Offset Address |              |                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |   |   |          |   |   |
|---------|----------------|--------------|---------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|---|---|----------|---|---|
|         | 0x00D4         |              |                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    | PERI_CRG53    |    |    |    |    |    |   |   | 0x0000_0711       |   |   |   |   |          |   |   |
| Bit     | 31             | 30           | 29                                                | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |
| Name    | reserved       |              |                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   | gpu_cken |   |   |
| Reset   | 0              | 0            | 0                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 1  | 1  | 1 | 1 | 0                 | 0 | 0 | 1 | 0 | 0        | 0 | 1 |
| Bits    | Access         | Name         | Description                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [31:11] | RW             | reserved     | Reserved                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [10]    | RW             | gpu_pp2_cken | PP1 clock gating<br>0: disabled<br>1: enabled     |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [9]     | RW             | gpu_pp1_cken | PP0 clock gating<br>0: disabled<br>1: enabled     |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [8]     | RW             | gpu_pp0_cken | GP clock gating<br>0: disabled<br>1: enabled      |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [7:5]   | RW             | reserved     | Reserved                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [4]     | RW             | gpu_srst_req | GPU module soft reset<br>0: not reset<br>1: reset |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [3:1]   | RW             | reserved     | Reserved                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |
| [0]     | RW             | gpu_cken     | GPU clock gating<br>0: disabled<br>1: enabled     |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |          |   |   |

## PERI\_CRG54

PERI\_CRG54 is a VDP clock and soft reset control register.



| Offset Address<br>0x00D8 |          |                    |                    |                                                                                 |                    |              |          |    |    |    |    | Register Name<br>PERI_CRG54 |                  |               |               |               |               |          |    |    |    |    |   | Total Reset Value<br>0x0401_007F |                |            |                |            |         |             |   |   |  |  |  |
|--------------------------|----------|--------------------|--------------------|---------------------------------------------------------------------------------|--------------------|--------------|----------|----|----|----|----|-----------------------------|------------------|---------------|---------------|---------------|---------------|----------|----|----|----|----|---|----------------------------------|----------------|------------|----------------|------------|---------|-------------|---|---|--|--|--|
| Bit                      | 31       | 30                 | 29                 | 28                                                                              | 27                 | 26           | 25       | 24 | 23 | 22 | 21 | 20                          | 19               | 18            | 17            | 16            | 15            | 14       | 13 | 12 | 11 | 10 | 9 | 8                                | 7              | 6          | 5              | 4          | 3       | 2           | 1 | 0 |  |  |  |
| Name                     | reserved | vou_srst_req       | vo_hd_hdmi_clk_sel | vdp_clk_sel                                                                     | vo_sd_hdmi_clk_sel | hdmi_clk_sel | reserved |    |    |    |    |                             | vdac_ch0_clk_sel | vo_hd_clk_div | vo_hd_clk_sel | vo_sd_clk_div | vo_sd_clk_sel | reserved |    |    |    |    |   | vdac_ch0_cken                    | vo_hdiate_cken | vo_hd_cken | vo_sdiate_cken | vo_sd_cken | vo_cken | vo_bus_cken |   |   |  |  |  |
| Reset                    | 0        | 0                  | 0                  | 0                                                                               | 0                  | 1            | 0        | 0  | 0  | 0  | 0  | 0                           | 0                | 0             | 1             | 0             | 0             | 0        | 0  | 0  | 0  | 0  | 0 | 0                                | 0              | 1          | 1              | 1          | 1       | 1           | 1 |   |  |  |  |
| Bits                     | Access   | Name               |                    | Description                                                                     |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [31]                     | RW       | reserved           |                    | Reserved                                                                        |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [30]                     | RW       | vou_srst_req       |                    | VOU soft reset<br>0: not reset<br>1: reset                                      |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [29]                     | RW       | vo_hd_hdmi_clk_sel |                    | Ratio of clk_vo_hd to clk_hdmi<br>0: 1:1<br>1: 1:2                              |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [28]                     | RW       | vdp_clk_sel        |                    | VDP clock select<br>0: 300 MHz<br>1: 200 MHz                                    |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [27]                     | RW       | vo_sd_hdmi_clk_sel |                    | Ratio of clk_vo_sd to clk_hdmi<br>0: 1:1<br>1: 1:2                              |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [26]                     | RW       | hdmi_clk_sel       |                    | HDMI clock select<br>0: clk_vo_sd<br>1: clk_vo_hd                               |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [25:21]                  | RW       | reserved           |                    | Reserved                                                                        |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [20]                     | RW       | vdac_ch0_clk_sel   |                    | VDAC channel 0 clock select<br>0: clk_date_sd<br>1: clk_date_hd                 |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |
| [19:18]                  | RW       | vo_hd_clk_div      |                    | VO HD clock divider<br>00: divided by 2<br>01: divided by 4<br>1X: divided by 1 |                    |              |          |    |    |    |    |                             |                  |               |               |               |               |          |    |    |    |    |   |                                  |                |            |                |            |         |             |   |   |  |  |  |



|         |    |               |                                                                                 |
|---------|----|---------------|---------------------------------------------------------------------------------|
| [17:16] | RW | vo_hd_clk_sel | VO HD clock select<br>00: clk_vo_sd_ini<br>01: clk_vo_hd0_ini<br>1X: reserved   |
| [15:14] | RW | vo_sd_clk_div | VO SD clock divider<br>00: divided by 2<br>01: divided by 4<br>1X: divided by 1 |
| [13:12] | RW | vo_sd_clk_sel | VO SD clock select<br>00: clk_vo_sd_ini<br>01: clk_vo_hd0_ini<br>1X: reserved   |
| [11:7]  | RW | reserved      | Reserved                                                                        |
| [6]     | RW | vdac_ch0_cken | VDAC channel 0 clock gating<br>0: disabled<br>1: enabled                        |
| [5]     | RW | vo_hdate_cken | VO HDATE clock gating<br>0: disabled<br>1: enabled                              |
| [4]     | RW | vo_hd_cken    | VO HD clock gating<br>0: disabled<br>1: enabled                                 |
| [3]     | RW | vo_sdate_cken | VO SDATE clock gating<br>0: disabled<br>1: enabled                              |
| [2]     | RW | vo_sd_cken    | VO SD clock gating<br>0: disabled<br>1: enabled                                 |
| [1]     | RW | vo_cken       | VO clock gating<br>0: disabled<br>1: enabled                                    |
| [0]     | RW | vo_bus_cken   | VO bus clock gating<br>0: disabled<br>1: enabled                                |

## PERI\_CRG60

PERI\_CRG60 is a VPSS clock and soft reset control register.



| Offset Address |          |                 |    |                                                                                                                                                                                  |    |    |    |    |    |    |    | Register Name |                |                 |    |    |    |          |              |          |    |               |          | Total Reset Value |           |   |   |   |   |   |   |   |  |  |  |
|----------------|----------|-----------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|---------------|----------------|-----------------|----|----|----|----------|--------------|----------|----|---------------|----------|-------------------|-----------|---|---|---|---|---|---|---|--|--|--|
| 0x00F0         |          |                 |    |                                                                                                                                                                                  |    |    |    |    |    |    |    | PERI_CRG60    |                |                 |    |    |    |          |              |          |    |               |          | 0x0000_0001       |           |   |   |   |   |   |   |   |  |  |  |
| Bit            | 31       | 30              | 29 | 28                                                                                                                                                                               | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19             | 18              | 17 | 16 | 15 | 14       | 13           | 12       | 11 | 10            | 9        | 8                 | 7         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | reserved |                 |    |                                                                                                                                                                                  |    |    |    |    |    |    |    |               | vpssclk_loaden | vpssclk_skipcfg |    |    |    | reserved | vpss_clk_sel | reserved |    | vpss_srst_req | reserved |                   | vpss_cken |   |   |   |   |   |   |   |  |  |  |
| Reset          | 0        | 0               | 0  | 0                                                                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0              | 0               | 0  | 0  | 0  | 0        | 0            | 0        | 0  | 0             | 0        | 0                 | 0         | 0 | 0 | 0 | 1 |   |   |   |  |  |  |
| Bits           | Access   | Name            |    | Description                                                                                                                                                                      |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [31:18]        | RW       | reserved        |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [17]           | RW       | vpssclk_loaden  |    | VPSS pulse filter/frequency scale enable<br>0: disabled<br>1: enabled                                                                                                            |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [16:12]        | RW       | vpssclk_skipcfg |    | VPSS pulse filter/frequency scale<br>0x0: No pulse is filtered out.<br>0x1: One pulse is filtered out.<br>0x2: Two pulses are filtered out.<br>The rule applies to other values. |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [11:10]        | RW       | reserved        |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [9:8]          | RW       | vpss_clk_sel    |    | VPSS clock select<br>00: 300 MHz<br>01: reserved<br>10: reserved<br>11: 400 MHz                                                                                                  |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [7:5]          | RW       | reserved        |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [4]            | RW       | vpss_srst_req   |    | VPSS soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [3:1]          | RW       | reserved        |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |
| [0]            | RW       | vpss_cken       |    | VPSS clock gating<br>0: disabled<br>1: enabled                                                                                                                                   |    |    |    |    |    |    |    |               |                |                 |    |    |    |          |              |          |    |               |          |                   |           |   |   |   |   |   |   |   |  |  |  |



## PERI\_CRG63

PERI\_CRG63 is a PVR-1 clock and soft reset control register.

|         | Offset Address |                |    |    |    |                                                         |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
|---------|----------------|----------------|----|----|----|---------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|--|--|--|
|         | 0x00FC         |                |    |    |    |                                                         |    |    |    |    |    |    |    |    |    |    | PERI_CRG63    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_001F       |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Bit     | 31             | 30             | 29 | 28 | 27 | 26                                                      | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Name    | reserved       |                |    |    |    |                                                         |    |    |    |    |    |    |    |    |    |    | reserved      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | reserved          |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| Reset   | 0              | 0              | 0  | 0  | 0  | 0                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |
| Bits    | Access         | Name           |    |    |    | Description                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [31:23] | RW             | reserved       |    |    |    | Reserved                                                |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [22]    | RW             | pvr_srst_req   |    |    |    | PVR soft reset<br>0: not reset<br>1: reset              |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [21:17] | RW             | reserved       |    |    |    | Reserved                                                |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [16]    | RW             | pvr_tsi2_pcrtl |    |    |    | PVR TSI2 phase select<br>0: normal phase<br>1: inverted |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [15]    | RW             | pvr_tsi1_pcrtl |    |    |    | PVR TSI1 phase select<br>0: normal phase<br>1: inverted |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [14:5]  | RW             | reserved       |    |    |    | Reserved                                                |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [4]     | RW             | pvr_tsi2_cken  |    |    |    | PVR TSI2 clock gating<br>0: disabled<br>1: enabled      |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [3]     | RW             | pvr_tsi1_cken  |    |    |    | PVR TSI1 clock gating<br>0: disabled<br>1: enabled      |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |
| [2]     | RW             | pvr_27m_cken   |    |    |    | PVR 27M clock gating<br>0: disabled<br>1: enabled       |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |  |



|     |    |              |                                                   |
|-----|----|--------------|---------------------------------------------------|
| [1] | RW | pvr_dmx_cken | PVR clock gating<br>0: disabled<br>1: enabled     |
| [0] | RW | pvr_bus_cken | PVR bus clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG64

PERI\_CRG64 is a PVR-2 clock and soft reset control register.

|         | Offset Address<br>0x0100 |                    |                                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG64 |    |                  |    |                |    |   |   | Total Reset Value<br>0x0000_0000 |   |          |   |   |   |   |   |
|---------|--------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|------------------|----|----------------|----|---|---|----------------------------------|---|----------|---|---|---|---|---|
| Bit     | 31                       | 30                 | 29                                                                                                                                                                              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13               | 12 | 11             | 10 | 9 | 8 | 7                                | 6 | 5        | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 |                    |                                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    | pvr_dmx_clkdiv_cfg          |    | sw_dmxclk_loaden |    | sw_dmx_clk_div |    |   |   | pvr_dmx_clk_sel                  |   | reserved |   |   |   |   |   |
| Reset   | 0                        | 0                  | 0                                                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0                | 0  | 0              | 0  | 0 | 0 | 0                                | 0 | 0        | 0 | 0 | 0 |   |   |
| Bits    | Access                   | Name               | Description                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |                  |    |                |    |   |   |                                  |   |          |   |   |   |   |   |
| [31:11] | RW                       | reserved           | Reserved                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |                  |    |                |    |   |   |                                  |   |          |   |   |   |   |   |
| [10]    | RW                       | pvr_dmx_clkdiv_cfg | PVR DEMUX clock divider select<br>0: configured by software<br>1: configured by hardware                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |                  |    |                |    |   |   |                                  |   |          |   |   |   |   |   |
| [9]     | RW                       | sw_dmxclk_loaden   | PVR pulse filter/frequency scale enable<br>0: disabled<br>1: enabled                                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |                  |    |                |    |   |   |                                  |   |          |   |   |   |   |   |
| [8:4]   | RW                       | sw_dmx_clk_div     | PVR pulse filter/frequency scale<br>0x0: No pulse is filtered out.<br>0x1: One pulse is filtered out.<br>0x2: Two pulses are filtered out.<br>The rule applies to other values. |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |                  |    |                |    |   |   |                                  |   |          |   |   |   |   |   |



|       |    |                 |                                                                      |
|-------|----|-----------------|----------------------------------------------------------------------|
| [3:2] | RW | pvr_dmx_clk_sel | PVR DEMUX clock select<br>00: 250 MHz<br>01: 288 MHz<br>1X: reserved |
| [1:0] | RW | reserved        | Reserved                                                             |

## PERI\_CRG67

PERI\_CRG67 is a HDMITX\_CTRL clock and soft reset control register.

|         | Offset Address<br>0x010C |                          |    |                                                            |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG67 |          |                         |          |                      |                          |          |          | Total Reset Value<br>0x0000_003F |                     |                      |                     |                      |                      |   |   |
|---------|--------------------------|--------------------------|----|------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----------|-------------------------|----------|----------------------|--------------------------|----------|----------|----------------------------------|---------------------|----------------------|---------------------|----------------------|----------------------|---|---|
| Bit     | 31                       | 30                       | 29 | 28                                                         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14       | 13                      | 12       | 11                   | 10                       | 9        | 8        | 7                                | 6                   | 5                    | 4                   | 3                    | 2                    | 1 | 0 |
| Name    | reserved                 |                          |    |                                                            |    |    |    |    |    |    |    |    |    |    |    |    | hdmitx_ctrl_asclk_sel       | reserved | hdmitx_ctrl_cec_clk_sel | reserved | hdmitx_ctrl_srst_req | hdmitx_ctrl_bus_srst_req | reserved | reserved | hdmitx_ctrl_as_cken              | hdmitx_ctrl_os_cken | hdmitx_ctrl_mhl_cken | hdmitx_ctrl_id_cken | hdmitx_ctrl_cec_cken | hdmitx_ctrl_bus_cken |   |   |
| Reset   | 0                        | 0                        | 0  | 0                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0        | 0                       | 0        | 0                    | 0                        | 0        | 0        | 1                                | 1                   | 1                    | 1                   | 1                    | 1                    |   |   |
| Bits    | Access                   | Name                     |    | Description                                                |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [31:15] | RW                       | reserved                 |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [14]    | RW                       | hdmitx_ctrl_asclk_sel    |    | HDMI TX ASCLK select<br>0: CRG (100 MHz)<br>1: HDMI TX PHY |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [13]    | RW                       | reserved                 |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [12]    | RW                       | hdmitx_ctrl_cec_clk_sel  |    | HDMI TX CEC clock select<br>0: 2 MHz<br>1: 2.02 MHz        |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [11:10] | RW                       | reserved                 |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [9]     | RW                       | hdmitx_ctrl_srst_req     |    | HDMI TX soft reset<br>0: not reset<br>1: reset             |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [8]     | RW                       | hdmitx_ctrl_bus_srst_req |    | HDMI TX bus soft reset<br>0: not reset<br>1: reset         |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |
| [7:6]   | RW                       | reserved                 |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |    |    |    |                             |          |                         |          |                      |                          |          |          |                                  |                     |                      |                     |                      |                      |   |   |



|     |    |                      |                                                       |
|-----|----|----------------------|-------------------------------------------------------|
| [5] | RW | hdmitx_ctrl_as_cke_n | HDMI TX AS clock gating<br>0: disabled<br>1: enabled  |
| [4] | RW | hdmitx_ctrl_os_cke_n | HDMI TX OS clock gating<br>0: disabled<br>1: enabled  |
| [3] | RW | hdmitx_ctrl_mhl_cken | HDMI TX clock gating<br>0: disabled<br>1: enabled     |
| [2] | RW | hdmitx_ctrl_id_cke_n | HDMI TX ID clock gating<br>0: disabled<br>1: enabled  |
| [1] | RW | hdmitx_ctrl_cec_cken | HDMI TX CEC clock gating<br>0: disabled<br>1: enabled |
| [0] | RW | hdmitx_ctrl_bus_cken | HDMI TX bus clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG68

PERI\_CRG68 is a HDMITX\_PHY clock and soft reset control register.

|        | Offset Address |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |                     |          |                     |   |   |   |   |
|--------|----------------|----------|----|----|----|-------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---------------------|----------|---------------------|---|---|---|---|
|        | 0x0110         |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | PERI_CRG68    |    |    |    |    |    |   |   | 0x0000_0001       |   |                     |          |                     |   |   |   |   |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5                   | 4        | 3                   | 2 | 1 | 0 |   |
| Name   | reserved       |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   | hdmitx_phy_srst_req | reserved | hdmitx_phy_bus_cken |   |   |   |   |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0                   | 0        | 0                   | 0 | 0 | 0 | 0 |
| Bits   | Access         | Name     |    |    |    | Description |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |                     |          |                     |   |   |   |   |
| [31:5] | RW             | reserved |    |    |    | Reserved    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |                     |          |                     |   |   |   |   |



|       |    |                     |                                                           |
|-------|----|---------------------|-----------------------------------------------------------|
| [4]   | RW | hdmitx_phy_srst_req | HDMI TX PHY soft reset<br>0: not reset<br>1: reset        |
| [3:1] | RW | reserved            | Reserved                                                  |
| [0]   | RW | hdmitx_phy_bus_cken | HDMI TX PHY bus clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG69

PERI\_CRG69 is an ADAC clock and soft reset control register.

|        | Offset Address<br>0x0114 |               |    |                                                    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG69 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0001 |               |          |           |   |   |   |   |
|--------|--------------------------|---------------|----|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---------------|----------|-----------|---|---|---|---|
| Bit    | 31                       | 30            | 29 | 28                                                 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6             | 5        | 4         | 3 | 2 | 1 | 0 |
| Name   | reserved                 |               |    |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  | adac_srst_req | reserved | adac_cken |   |   |   |   |
| Reset  | 0                        | 0             | 0  | 0                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0             | 0        | 0         | 0 | 1 |   |   |
| Bits   | Access                   | Name          |    | Description                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |          |           |   |   |   |   |
| [31:5] | RW                       | reserved      |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |          |           |   |   |   |   |
| [4]    | RW                       | adac_srst_req |    | ADAC soft reset<br>0: not reset<br>1: reset        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |          |           |   |   |   |   |
| [3:1]  | RW                       | reserved      |    | Reserved                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |          |           |   |   |   |   |
| [0]    | RW                       | adac_cken     |    | ADAC bus clock gating<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |          |           |   |   |   |   |

## PERI\_CRG70

PERI\_CRG70 is an AIAO clock and soft reset control register.



| Offset Address |          |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    | Register Name |               |          |                |                 |          |    |    |    |               |          |   | Total Reset Value |   |           |   |   |   |   |   |   |  |  |  |
|----------------|----------|-----------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---------------|---------------|----------|----------------|-----------------|----------|----|----|----|---------------|----------|---|-------------------|---|-----------|---|---|---|---|---|---|--|--|--|
| 0x0118         |          |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    | PERI_CRG70    |               |          |                |                 |          |    |    |    |               |          |   | 0x0000_0001       |   |           |   |   |   |   |   |   |  |  |  |
| Bit            | 31       | 30              | 29 | 28 | 27                                                                                                                                                                               | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19            | 18       | 17             | 16              | 15       | 14 | 13 | 12 | 11            | 10       | 9 | 8                 | 7 | 6         | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | reserved |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    |               | aiao_mclk_sel | reserved | aiaoclk_loaden | aiaoclk_skipcfg | reserved |    |    |    | aiao_srst_req | reserved |   |                   |   | aiao_cken |   |   |   |   |   |   |  |  |  |
| Reset          | 0        | 0               | 0  | 0  | 0                                                                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             | 0        | 0              | 0               | 0        | 0  | 0  | 0  | 0             | 0        | 0 | 0                 | 0 | 0         | 0 | 0 | 0 | 1 |   |   |  |  |  |
| Bits           | Access   | Name            |    |    | Description                                                                                                                                                                      |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [31:22]        | RW       | reserved        |    |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [21:20]        | RW       | aiao_mclk_sel   |    |    | AIAO MCLK source select<br>00: 1000 MHz<br>01: 1200 MHz<br>1X: 1500 MHz                                                                                                          |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [19:18]        | RW       | reserved        |    |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [17]           | RW       | aiaoclk_loaden  |    |    | AIAO pulse filter/frequency scale enable<br>0: disabled<br>1: enabled                                                                                                            |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [16:12]        | RW       | aiaoclk_skipcfg |    |    | AIAO pulse filter/frequency scale<br>0x0: No pulse is filtered out.<br>0x1: One pulse is filtered out.<br>0x2: Two pulses are filtered out.<br>The rule applies to other values. |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [11:5]         | RW       | reserved        |    |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [4]            | RW       | aiao_srst_req   |    |    | AIAO soft reset<br>0: not reset<br>1: reset                                                                                                                                      |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [3:1]          | RW       | reserved        |    |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |
| [0]            | RW       | aiao_cken       |    |    | AIAO clock gating<br>0: disabled<br>1: enabled                                                                                                                                   |    |    |    |    |    |    |               |               |          |                |                 |          |    |    |    |               |          |   |                   |   |           |   |   |   |   |   |   |  |  |  |

## PERI\_CRG71

PERI\_CRG71 is a VDAC clock and soft reset control register.



|         | Offset Address<br>0x011C |                  |    |    |    |                                                       |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG71 |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value<br>0x0000_0001 |                |  |  |
|---------|--------------------------|------------------|----|----|----|-------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-----------------------------|----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----------------------------------|----------------|--|--|
| Bit     | 31                       | 30               | 29 | 28 | 27 | 26                                                    | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                  |                |  |  |
| Name    | reserved                 |                  |    |    |    |                                                       |    |    |    |    |    |    |    |    |    |    | vdac_c_clk_pctrl            | reserved |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  | vdac_chop_cken |  |  |
| Reset   | 0                        | 0                | 0  | 0  | 0  | 0                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0        | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |   |                                  |                |  |  |
| Bits    | Access                   | Name             |    |    |    | Description                                           |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  |                |  |  |
| [31:17] | RW                       | reserved         |    |    |    | Reserved                                              |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  |                |  |  |
| [16]    | RW                       | vdac_c_clk_pctrl |    |    |    | VDAC C phase select<br>0: normal phase<br>1: inverted |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  |                |  |  |
| [15:1]  | RW                       | reserved         |    |    |    | Reserved                                              |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  |                |  |  |
| [0]     | RW                       | vdac_chop_cken   |    |    |    | VDAC chop clock gating<br>0: disabled<br>1: enabled   |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                                  |                |  |  |

## PERI\_CRG72

PERI\_CRG72 is an FE PHY clock and soft reset control register.

|        | Offset Address<br>0x0120 |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG72 |          |    |    |    |                |          |   |   |   |            |   |   |   |   |   | Total Reset Value<br>0x0000_0011 |  |  |  |
|--------|--------------------------|----------|----|----|----|-------------|----|----|----|----|----|----|----|----|----|----|-----------------------------|----------|----|----|----|----------------|----------|---|---|---|------------|---|---|---|---|---|----------------------------------|--|--|--|
| Bit    | 31                       | 30       | 29 | 28 | 27 | 26          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14       | 13 | 12 | 11 | 10             | 9        | 8 | 7 | 6 | 5          | 4 | 3 | 2 | 1 | 0 |                                  |  |  |  |
| Name   | reserved                 |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | fephy_clk_sel               | reserved |    |    |    | fephy_srst_req | reserved |   |   |   | fephy_cken |   |   |   |   |   |                                  |  |  |  |
| Reset  | 0                        | 0        | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0        | 0  | 0  | 0  | 0              | 0        | 0 | 0 | 0 | 0          | 0 | 1 | 0 | 0 | 0 | 1                                |  |  |  |
| Bits   | Access                   | Name     |    |    |    | Description |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |                |          |   |   |   |            |   |   |   |   |   |                                  |  |  |  |
| [31:9] | RW                       | reserved |    |    |    | Reserved    |    |    |    |    |    |    |    |    |    |    |                             |          |    |    |    |                |          |   |   |   |            |   |   |   |   |   |                                  |  |  |  |



|       |    |                |                                                  |
|-------|----|----------------|--------------------------------------------------|
| [8]   | RW | fephy_clk_sel  | FE PHY clock select<br>0: 25 MHz<br>1: 40 MHz    |
| [7:5] | RW | reserved       | Reserved                                         |
| [4]   | RW | fephy_srst_req | FE PHY soft reset<br>0: not reset<br>1: reset    |
| [3:1] | RW | reserved       | Reserved                                         |
| [0]   | RW | fephy_cken     | FE PHY clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG73

PERI\_CRG73 is a GPU\_LP clock and soft reset control register.

|         | Offset Address<br>0x0124 |                      |    |    |                                                                                                              |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG73 |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   | Total Reset Value<br>0x0000_0206 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------|--------------------------|----------------------|----|----|--------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|---|---|---|---|---|----------------------|---|---|----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit     | 31                       | 30                   | 29 | 28 | 27                                                                                                           | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2                    | 1 | 0 |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name    | reserved                 |                      |    |    |                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   | gpu_freq_sel_cfg_crg |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset   | 0                        | 0                    | 0  | 0  | 0                                                                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1                    | 1 | 0 |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits    | Access                   | Name                 |    |    | Description                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:11] | RW                       | reserved             |    |    | Reserved                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [10]    | RW                       | gpu_sw_begin_cfg     |    |    | GPU switch start<br>0: not started<br>1: started                                                             |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [9]     | RW                       | gpu_begin_cfg_bypass |    |    | GPU switch start bypass signal<br>0: signal output by the state machine<br>1: signal configured by registers |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [8:3]   | RW                       | reserved             |    |    | Reserved                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |   |   |   |   |   |                      |   |   |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



|       |    |                      |                                                                                                                                                    |
|-------|----|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | RW | gpu_freq_sel_cfg_crg | GPU clock select<br>000: 432 MHz<br>001: 400 MHz<br>010: 375 MHz<br>011: 345.6 MHz<br>100: 300 MHz<br>101: 250 MHz<br>110: 200 MHz<br>111: 500 MHz |
|-------|----|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|

## PERI\_CRG74

PERI\_CRG74 is a DDR\_LP clock and soft reset control register.

|         | Offset Address 0x0128 |                      |    |                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    | Register Name PERI_CRG74 |    |                      |    |          |    |   |   | Total Reset Value 0x0000_0204 |   |   |   |   |   |   |   |
|---------|-----------------------|----------------------|----|--------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----------------------|----|----------|----|---|---|-------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                    | 30                   | 29 | 28                                                                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14 | 13                   | 12 | 11       | 10 | 9 | 8 | 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved              |                      |    |                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    | ddr_sw_begin_cfg         |    | ddr_begin_cfg_bypass |    | reserved |    |   |   | ddr_freq_sel_cfg_crg          |   |   |   |   |   |   |   |
| Reset   | 0                     | 0                    | 0  | 0                                                                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0  | 0                    | 0  | 0        | 1  | 0 | 0 | 0                             | 0 | 0 | 1 | 0 | 0 |   |   |
| Bits    | Access                | Name                 |    | Description                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |                      |    |          |    |   |   |                               |   |   |   |   |   |   |   |
| [31:11] | RW                    | reserved             |    | Reserved                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |                      |    |          |    |   |   |                               |   |   |   |   |   |   |   |
| [10]    | RW                    | ddr_sw_begin_cfg     |    | DDR switch start<br>0: not started<br>1: started                                                             |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |                      |    |          |    |   |   |                               |   |   |   |   |   |   |   |
| [9]     | RW                    | ddr_begin_cfg_bypass |    | DDR switch start bypass signal<br>0: signal output by the state machine<br>1: signal configured by registers |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |                      |    |          |    |   |   |                               |   |   |   |   |   |   |   |
| [8:3]   | RW                    | reserved             |    | Reserved                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |                      |    |          |    |   |   |                               |   |   |   |   |   |   |   |



|       |    |                      |                                                                                                                                                                 |
|-------|----|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | RW | ddr_freq_sel_cfg_crg | DDR clock select<br>000: DPLL output<br>001: DPLL output<br>010: DPLL output<br>011: DPLL output<br>100: 24 MHz<br>101: 400 MHz<br>110: 300 MHz<br>111: 200 MHz |
|-------|----|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|

## PERI\_CRG85

PERI\_CRG85 is an SW\_READBACK register.

| Offset Address |        |    |    | Register Name      |    |    |    |                                         |    |    |    |             |    |    |    |    |    |    |    | Total Reset Value |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|--------|----|----|--------------------|----|----|----|-----------------------------------------|----|----|----|-------------|----|----|----|----|----|----|----|-------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit            | 0x0154 |    |    | PERI_CRG85         |    |    |    |                                         |    |    |    |             |    |    |    |    |    |    |    | 0x0000_0000       |    |    |   |   |   |   |   |   |   |   |   |   |
| Name           | 31     | 30 | 29 | 28                 | 27 | 26 | 25 | 24                                      | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12                | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reset          | 0      | 0  | 0  | 0                  | 0  | 0  | 0  | 0                                       | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           |        |    |    | Access             |    |    |    | Name                                    |    |    |    | Description |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [31]           | RO     |    |    | reserved           |    |    |    | Reserved                                |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [30:29]        | RO     |    |    | vdh_clk_seled      |    |    |    | VDH clock switch completion indicator   |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [28]           | RO     |    |    | reserved           |    |    |    | Reserved                                |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [27:26]        | RO     |    |    | mde3_clk_seled     |    |    |    | MDE3 clock switch completion indicator  |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [25:24]        | RO     |    |    | mde2_clk_seled     |    |    |    | MDE2 clock switch completion indicator  |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [23:22]        | RO     |    |    | mde1_clk_seled     |    |    |    | MDE1 clock switch completion indicator  |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [21:20]        | RO     |    |    | mde0_clk_seled     |    |    |    | MDE0 clock switch completion indicator  |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [19:18]        | RO     |    |    | sdio1_clk_seled    |    |    |    | SDIO1 clock switch completion indicator |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [17:16]        | RO     |    |    | sdio0_clk_seled    |    |    |    | SDIO0 clock switch completion indicator |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:14]        | RO     |    |    | reserved           |    |    |    | Reserved                                |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |
| [13:12]        | RO     |    |    | core_bus_clk_seled |    |    |    | Bus clock switch completion indicator   |    |    |    |             |    |    |    |    |    |    |    |                   |    |    |   |   |   |   |   |   |   |   |   |   |



|        |    |                    |                                       |
|--------|----|--------------------|---------------------------------------|
| [11:9] | RO | ddr_clk_mux        | DDR clock switch completion indicator |
| [8]    | RO | ddr_clk_sw_ok_crg  | DDR PLL switch completion indicator   |
| [7:5]  | RO | gpu_clk_mux        | GPU clock switch completion indicator |
| [4]    | RO | gpu_clk_sw_ok_cr_g | GPU PLL switch completion indicator   |
| [3:1]  | RO | cpu_clk_mux        | CPU clock switch completion indicator |
| [0]    | RO | cpu_clk_sw_ok_cr_g | CPU PLL switch completion indicator   |

## PERI\_CRG90

PERI\_CRG90 is an output reset control register.

|        | Offset Address<br>0x0168 |               |    |                                                                           |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG90 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |               |              |          |              |   |   |   |
|--------|--------------------------|---------------|----|---------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---------------|--------------|----------|--------------|---|---|---|
| Bit    | 31                       | 30            | 29 | 28                                                                        | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6             | 5            | 4        | 3            | 2 | 1 | 0 |
| Name   | reserved                 |               |    |                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  | mute_ctrl_out | dem_RST0_out | reserved | slic_RST_out |   |   |   |
| Reset  | 0                        | 0             | 0  | 0                                                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0             | 0            | 0        | 0            | 0 |   |   |
| Bits   | Access                   | Name          |    | Description                                                               |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |
| [31:4] | RW                       | reserved      |    | Reserved                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |
| [3]    | RW                       | mute_ctrl_out |    | Soft reset request of the off-chip MUTE pin<br>0: muted<br>1: not muted   |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |
| [2]    | RW                       | dem_RST0_out  |    | Soft reset request for off-chip demo 0<br>0: reset deasserted<br>1: reset |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |
| [1]    | RW                       | reserved      |    | Reserved                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |
| [0]    | RW                       | slic_RST_out  |    | Soft reset request for off-chip SLIC<br>0: reset deasserted<br>1: reset   |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |               |              |          |              |   |   |   |



## PERI\_CRG91

PERI\_CRG91 is a USB\_FREECLK\_DEC control register.

|        | Offset Address                                                                                      | Register Name     | Total Reset Value                                                                             |
|--------|-----------------------------------------------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------|
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | PERI_CRG91        | 0x0000_0000                                                                                   |
| Name   |                                                                                                     | reserved          | usb3_phy_cnt_out<br>usb2_phy2_cnt_out<br>usb2_phy_cnt_out                                     |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                   |                                                                                               |
| Bits   | Access                                                                                              | Name              | Description                                                                                   |
| [31:3] | RO                                                                                                  | reserved          | Reserved                                                                                      |
| [2]    | RO                                                                                                  | usb3_phy_cnt_out  | Readback of the USB3 PHY FREECLK count<br>0: FREECLK is not output.<br>1: FREECLK is output.  |
| [1]    | RO                                                                                                  | usb2_phy2_cnt_out | Readback of the USB2 PHY2 FREECLK count<br>0: FREECLK is not output.<br>1: FREECLK is output. |
| [0]    | RO                                                                                                  | usb2_phy_cnt_out  | Readback of the USB2 PHY FREECLK count<br>0: FREECLK is not output.<br>1: FREECLK is output.  |

## PERI\_CRG93

PERI\_CRG93 is a VDH\_RST\_READBACK register.



|        | Offset Address |                |    |                                                            |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |                |                |                |   |   |   |   |
|--------|----------------|----------------|----|------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|----------------|----------------|----------------|---|---|---|---|
|        | 0x0174         |                |    |                                                            |    |    |    |    |    |    |    |    |    |    |    |    | PERI_CRG93    |    |    |    |    |    |   |   | 0x0000_0000       |                |                |                |   |   |   |   |
| Bit    | 31             | 30             | 29 | 28                                                         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6              | 5              | 4              | 3 | 2 | 1 | 0 |
| Name   | reserved       |                |    |                                                            |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   | vdh_mfd_RST_OK | vdh_scd_RST_OK | vdh_all_RST_OK |   |   |   |   |
| Reset  | 0              | 0              | 0  | 0                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0              | 0              | 0              | 0 | 0 |   |   |
| Bits   | Access         | Name           |    | Description                                                |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |                |                |                |   |   |   |   |
| [31:3] | RO             | reserved       |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |                |                |                |   |   |   |   |
| [2]    | RO             | vdh_mfd_RST_OK |    | MFD reset status<br>0: reset deasserted<br>1: reset        |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |                |                |                |   |   |   |   |
| [1]    | RO             | vdh_scd_RST_OK |    | SCD reset status<br>0: reset deasserted<br>1: reset        |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |                |                |                |   |   |   |   |
| [0]    | RO             | vdh_all_RST_OK |    | VDH global reset status<br>0: reset deasserted<br>1: reset |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |                |                |                |   |   |   |   |

## PERI\_CRG94

PERI\_CRG94 is a WDG clock and soft reset control register.

|       | Offset Address |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |               |          |           |   |   |   |
|-------|----------------|------|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---------------|----------|-----------|---|---|---|
|       | 0x0178         |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    | PERI_CRG94    |    |    |    |    |    |   |   | 0x0000_0003       |   |               |          |           |   |   |   |
| Bit   | 31             | 30   | 29 | 28          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5             | 4        | 3         | 2 | 1 | 0 |
| Name  | reserved       |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   | wdg0_SRST_REQ | reserved | wdg0_CKEN |   |   |   |
| Reset | 0              | 0    | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0             | 0        | 0         | 0 |   |   |
| Bits  | Access         | Name |    | Description |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |               |          |           |   |   |   |



|        |    |               |                                                |
|--------|----|---------------|------------------------------------------------|
| [31:5] | RW | reserved      | Reserved                                       |
| [4]    | RW | wdg0_srst_req | WDG0 soft reset<br>0: not reset<br>1: reset    |
| [3:1]  | RW | reserved      | Reserved                                       |
| [0]    | RW | wdg0_cken     | WDG0 clock gating<br>0: disabled<br>1: enabled |

## PERI\_CRG95

PERI\_CRG95 is a PLL\_TEST clock and soft reset control register.

|        | Offset Address<br>0x017C |              |    |                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_CRG95 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0005 |   |   |   |             |              |             |   |
|--------|--------------------------|--------------|----|----------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|-------------|--------------|-------------|---|
| Bit    | 31                       | 30           | 29 | 28                                                                                     | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3           | 2            | 1           | 0 |
| Name   | reserved                 |              |    |                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   | test_clk_en | test_clk_sel | pll_test_en |   |
| Reset  | 0                        | 0            | 0  | 0                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 1           | 0            | 1           |   |
| Bits   | Access                   | Name         |    | Description                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |             |              |             |   |
| [31:3] | RW                       | reserved     |    | Reserved                                                                               |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |             |              |             |   |
| [2]    | RW                       | test_clk_en  |    | clk_test_out output enable<br>0: disabled<br>1: enabled                                |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |             |              |             |   |
| [1]    | RW                       | test_clk_sel |    | clk_test_out source select<br>0: CPU clock divided by 32<br>1: DDR clock divided by 16 |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |             |              |             |   |
| [0]    | RW                       | pll_test_en  |    | PLL test enable<br>0: disabled<br>1: enabled                                           |    |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |   |   |                                  |   |   |   |             |              |             |   |

## PERI\_CRG96

PERI\_CRG96 is a CPU RAM speed control register.



| Offset Address |          |                |    |    |                                                                                                     |    |    | Register Name |    |    |    |    |                |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------------|----|----|-----------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----------------|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0180         |          |                |    |    |                                                                                                     |    |    | PERI_CRG96    |    |    |    |    |                |    |    | 0x0000_A501       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28 | 27                                                                                                  | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19             | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |    |                                                                                                     |    |    |               |    |    |    |    | mem_adjust_cpu |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0  | 0  | 0                                                                                                   | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0                 | 1  | 0  | 1  | 0  | 0  | 1  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |   |
| Bits           | Access   | Name           |    |    | Description                                                                                         |    |    |               |    |    |    |    |                |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:19]        | RW       | reserved       |    |    | Reserved                                                                                            |    |    |               |    |    |    |    |                |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [18:0]         | RW       | mem_adjust_cpu |    |    | l2_dataram_delay[18:14] speed adjustment parameter<br>a7_ram_delay[13:0] speed adjustment parameter |    |    |               |    |    |    |    |                |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

PERI\_CRG97

**PERI\_CRG97** is a CPU RAM speed control register.

| Offset Address |          |                |    |    |                                                                                                                                                                                                                                                                         |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0184         |          |                |    |    |                                                                                                                                                                                                                                                                         |    |    | PERI_CRG97    |    |    |    |    |    |    |    | 0x0000_4212       |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28 | 27                                                                                                                                                                                                                                                                      | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |    |                                                                                                                                                                                                                                                                         |    |    |               |    |    |    |    |    |    |    |                   | mem_adjust_gpu |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0  | 0  | 0                                                                                                                                                                                                                                                                       | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0              | 1  | 0  | 0  | 0  | 1  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 |   |
| Bits           | Access   | Name           |    |    | Description                                                                                                                                                                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW       | reserved       |    |    | Reserved                                                                                                                                                                                                                                                                |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | mem_adjust_gpu |    |    | ema_rfs[15:13] speed adjustment parameter<br>emaw_rfs[12:11] speed adjustment parameter<br>ema_ras[10:8] speed adjustment parameter<br>emaw_ras[7:6] speed adjustment parameter<br>emaa_rft[5:3] speed adjustment parameter<br>emab_rft[2:0] speed adjustment parameter |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

PERI\_CRG100

**PERI\_CRG100** is a USB2 PHY2 clock and soft reset control register.



| Offset Address |          |                      |    |                                                                                            |    |    |    | Register Name |                      |    |    |    |    |    |    | Total Reset Value |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
|----------------|----------|----------------------|----|--------------------------------------------------------------------------------------------|----|----|----|---------------|----------------------|----|----|----|----|----|----|-------------------|----------|----|----|----|----|----|---|---|--------------------|---|---|---|---|---|---|---|
| 0x0190         |          |                      |    |                                                                                            |    |    |    | PERI_CRG100   |                      |    |    |    |    |    |    | 0x0000_0301       |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| Bit            | 31       | 30                   | 29 | 28                                                                                         | 27 | 26 | 25 | 24            | 23                   | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                      |    |                                                                                            |    |    |    |               | usb2_phy2_refclk_sel |    |    |    |    |    |    |                   | reserved |    |    |    |    |    |   |   | usb2_phy2_ref_cken |   |   |   |   |   |   |   |
| Reset          | 0        | 0                    | 0  | 0                                                                                          | 0  | 0  | 0  | 0             | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0        | 0  | 0  | 0  | 0  | 1  | 1 | 0 | 0                  | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name                 |    | Description                                                                                |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [31:17]        | RW       | reserved             |    | Reserved                                                                                   |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [16]           | RW       | usb2_phy2_refclk_sel |    | USB2 PHY reference clock select<br>0: crystal oscillator clock<br>1: 24 MHz internal clock |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [15:10]        | RW       | reserved             |    | Reserved                                                                                   |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [9]            | RW       | usb2_phy2_srst_treq  |    | USB2 PHY TPOR soft reset<br>0: not reset<br>1: reset                                       |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [8]            | RW       | usb2_phy2_srst_req   |    | USB2 PHY POR soft reset<br>0: not reset<br>1: reset                                        |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [7:1]          | RW       | reserved             |    | Reserved                                                                                   |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |
| [0]            | RW       | usb2_phy2_ref_cken   |    | USB2 PHY reference clock gating<br>0: disabled<br>1: enabled                               |    |    |    |               |                      |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                    |   |   |   |   |   |   |   |

PERI\_CRG101

**PERI\_CRG101** is a USB3 PHY clock and soft reset control register.



| Offset Address |          |                     |    |                                                                                            |    |    |    |    |    |    |    |    |    |    |    | Register Name |                 |                  |                     |          |                    |                   |          | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|---------------------|----|--------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|-----------------|------------------|---------------------|----------|--------------------|-------------------|----------|-------------------|---|---|---|---|---|---|---|---|
| 0x0194         |          |                     |    |                                                                                            |    |    |    |    |    |    |    |    |    |    |    | PERI_CRG101   |                 |                  |                     |          |                    |                   |          | 0x0000_0431       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30                  | 29 | 28                                                                                         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15              | 14               | 13                  | 12       | 11                 | 10                | 9        | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                     |    |                                                                                            |    |    |    |    |    |    |    |    |    |    |    |               | usb3_ref_ssp_en | usb3_ref_use_pad | usb3_phy_refclk_sel | reserved | usb3_phy_srst_treq | usb3_phy_srst_req | reserved | usb3_phy_ref_cken |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0                   | 0  | 0                                                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0               | 0                | 0                   | 0        | 0                  | 1                 | 0        | 0                 | 0 | 1 | 1 | 0 | 0 | 0 | 1 |   |
| Bits           | Access   | Name                |    | Description                                                                                |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [31:11]        | RW       | reserved            |    | Reserved                                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [10]           | RW       | usb3_ref_ssp_en     |    | USB3 PHY super-speed domain clock enable<br>0: disabled<br>1: enabled                      |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [9]            | RW       | usb3_ref_use_pad    |    | USB3 PHY reference clock select<br>0: internal CRG<br>1: pad                               |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [8]            | RW       | usb3_phy_refclk_sel |    | USB3 PHY reference clock select<br>0: crystal oscillator clock<br>1: 24 MHz internal clock |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [7:6]          | RW       | reserved            |    | Reserved                                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [5]            | RW       | usb3_phy_srst_treq  |    | USB3 PHY TPOR soft reset<br>0: not reset<br>1: reset                                       |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [4]            | RW       | usb3_phy_srst_req   |    | USB3 PHY POR soft reset<br>0: not reset<br>1: reset                                        |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [3:1]          | RW       | reserved            |    | Reserved                                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |
| [0]            | RW       | usb3_phy_ref_cken   |    | USB3 PHY reference clock gating<br>0: disabled<br>1: enabled                               |    |    |    |    |    |    |    |    |    |    |    |               |                 |                  |                     |          |                    |                   |          |                   |   |   |   |   |   |   |   |   |

## PERI\_CRG102

PERI\_CRG102 is a USB2 CTRL2 clock and soft reset control register.



| Offset Address |          |                        |    |                                                                    |    |    |    | Register Name |                 |    |    |    |    |    |    | Total Reset Value |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
|----------------|----------|------------------------|----|--------------------------------------------------------------------|----|----|----|---------------|-----------------|----|----|----|----|----|----|-------------------|----------|----|----|----|----|----|---|---|------------------|---|---|---|---|---|---|---|
| 0x0198         |          |                        |    |                                                                    |    |    |    | PERI_CRG102   |                 |    |    |    |    |    |    | 0x0011_5037       |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| Bit            | 31       | 30                     | 29 | 28                                                                 | 27 | 26 | 25 | 24            | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                        |    |                                                                    |    |    |    |               | usb2_clk48_sel1 |    |    |    |    |    |    |                   | reserved |    |    |    |    |    |   |   | usb2_utmi0_cken1 |   |   |   |   |   |   |   |
| Reset          | 0        | 0                      | 0  | 0                                                                  | 0  | 0  | 0  | 0             | 0               | 0  | 0  | 1  | 0  | 0  | 0  | 1                 | 0        | 1  | 0  | 1  | 0  | 0  | 0 | 0 | 0                | 1 | 1 | 0 | 1 | 1 | 1 |   |
| Bits           | Access   | Name                   |    | Description                                                        |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [31:21]        | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [20]           | RW       | usb2_clk48_sel1        |    | USB2 CLK48 clock source<br>0: provided by the CRG<br>1: PHY output |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [19:17]        | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [16]           | RW       | usb2_hst_phy_srst_req1 |    | USB2 CTRL hst_phy soft reset<br>0: not reset<br>1: reset           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [15]           | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [14]           | RW       | usb2_utmi0_srst_req1   |    | USB2 CTRL UTMI0 soft reset<br>0: not reset<br>1: reset             |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [13]           | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [12]           | RW       | usb2_bus_srst_req1     |    | USB2 CTRL bus soft reset<br>0: not reset<br>1: reset               |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [11:6]         | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [5]            | RW       | usb2_utmi0_cken1       |    | USB2 CTRL UTMI0 clock gating<br>0: disabled<br>1: enabled          |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [4]            | RW       | usb2_hst_phy_cken1     |    | USB2 CTRL hst_phy clock gating<br>0: disabled<br>1: enabled        |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |
| [3]            | RW       | reserved               |    | Reserved                                                           |    |    |    |               |                 |    |    |    |    |    |    |                   |          |    |    |    |    |    |   |   |                  |   |   |   |   |   |   |   |



|     |    |                    |                                                             |
|-----|----|--------------------|-------------------------------------------------------------|
| [2] | RW | usb2_ohci12m_cken1 | USB2 CTRL OHCI12M clock gating<br>0: disabled<br>1: enabled |
| [1] | RW | usb2_ohci48m_cken1 | USB2 CTRL OHCI48M clock gating<br>0: disabled<br>1: enabled |
| [0] | RW | usb2_bus_cken1     | USB2 CTRL bus clock gating<br>0: disabled<br>1: enabled     |

## 3.4 System Controller

### 3.4.1 Overview

The system controller controls the operating mode of the system, monitors the system status, manages the key functions of the system (such as the clock, reset, and pin multiplexing), and configures some functions of peripherals.

### 3.4.2 Features

The system controller has the following features:

- Controls and monitors the operating mode of the system.
- Controls the system clock and queries its status.
- Controls system address remapping and monitors the remapping status.
- Provides common peripheral registers.
- Controls pin multiplexing of the always-on area.
- Provides write protection for key registers.
- Provides chip ID registers.

### 3.4.3 Function Description

#### Operating Modes

The system supports three operating modes:

- Normal mode

Typically, the system works in normal mode. In this mode, the system is driven by the output clock of the on-chip PLL. All modules can work properly under this clock source.

- Slow mode

The slow mode is a low-speed mode. In this mode, the system is driven by the external crystal oscillator clock, and only some on-chip peripherals (such as the system controller, timer, and NANDC) can work. Modules (such as the DDRC) that require high-speed clocks cannot work.



- Doze mode

The doze mode is also a low-speed mode, but its speed is lower than that of the slow mode. Only a few on-chip peripherals can work in doze mode. In this mode, the system is driven by a 100 kHz low-frequency clock generated by dividing the frequency of the external crystal oscillator clock. Except the CPU and a few modules (such as the system controller, timer, IR, and UART1), most on-chip peripherals and the memory interfaces cannot work in this mode.

The always-on area can work in any of the preceding modes, whereas the power-off area can work only in normal or slow mode.

When the system operating mode is switched [PERI\\_CRG22](#), [PERI\\_CRG73](#), [PERI\\_CRG74](#), and [SC\\_CTRL](#) need to be configured to select working clocks.

The operating mode of the always-on area is switched by configuring [SC\\_CTRL\[mcu\\_bus\\_clk\\_sel\]](#) for switching the system clock source. These two bits define the target operating mode to be entered:

- 00: slow mode
- 01: normal mode
- 10: doze mode
- 11: reserved

The operating mode of the power-off area is switched by configuring [PERI\\_CRG22](#), [PERI\\_CRG73](#), and [PERI\\_CRG74](#) for selecting clock frequencies.

## Soft Reset

- The system controller can soft-reset the entire chip or some modules.
- After the global soft reset register [SC\\_SYSRES](#) is configured, the system controller sends a reset request to the on-chip reset module. Then the chip is reset.
- After the soft reset bit of a module in the system controller is configured, the system controller instructs the on-chip reset module to reset this module.
- After a request for resetting the power-off area is configured in the system controller, the entire power-off area is reset.

## System Address Remapping

The system controller supports address remapping and allows the address decoding unit to remap and reallocate the system storage address space. This section uses the mode of booting the system from the on-chip ROM as an example.

After POR, the system addresses are remapped. The addresses ranging from 0xFFFF\_0000 to 0xFFFF\_FFFF are mapped to the on-chip ROM. After the address remap is cleared by configuring [SC\\_CTRL\[remapclear\]](#), the addresses are mapped to the on-chip SRAM.

## Pin Multiplexing Control

The system controller supports pin multiplexing control for the always-on area. For details, see section [3.4.5 "Register Description."](#)



## Write Protection for Key Registers

To prevent the entire system from being affected by misoperations on the system controller, the system controller provides write protection for the following key configuration registers:

- Mode switching control register [SC\\_CTRL](#)
- System soft reset control register [SC\\_SYSRES](#)

Before writing to these key registers, you must disable the write protection function by configuring [SC\\_LOCKEN](#). After writes, you need to enable the write protection function by configuring [SC\\_LOCKEN](#) again so that these key registers are not overwritten by the software arbitrarily.



**NOTE**  
Write protection is not enabled for key registers after reset by default. You are advised to enable write protection by configuring SC\_LOCKEN when the system starts.

## Chip Flag Register

The system controller provides a chip ID register [SC\\_SYSID](#). It is a 32-bit read-only identifier register.

### 3.4.4 Register Summary

[Table 3-44](#) describes SYS\_CTRL registers.

**Table 3-44** Summary of SYS\_CTRL registers (base address: 0xF800\_0000)

| Offset Address | Register             | Description                                                      | Page                 |
|----------------|----------------------|------------------------------------------------------------------|----------------------|
| 0x0000         | SC_CTRL              | System control register                                          | <a href="#">3-75</a> |
| 0x0004         | SC_SYSRES            | System status register                                           | <a href="#">3-76</a> |
| 0x0040         | SC_LOW_POWER_CTRL    | Low-power control register                                       | <a href="#">3-76</a> |
| 0x0044         | SC_IO_REUSE_SEL      | MCU pin multiplexing control register                            | <a href="#">3-78</a> |
| 0x0048         | SC_CLKGATE_SRST_CTRL | MCU internal module clock gating and soft reset control register | <a href="#">3-80</a> |
| 0x0050         | SC_WDG_RST_CTRL      | Software-controlled WDG reset register                           | <a href="#">3-81</a> |
| 0x0058         | SC_DDRPHY_LP_EN      | DDR PHY low-power control register                               | <a href="#">3-82</a> |
| 0x0060         | SC MCU_HPM_CTRL      | HPM control register                                             | <a href="#">3-82</a> |
| 0x0064         | SC MCU_HPM_STAT      | HPM status register                                              | <a href="#">3-83</a> |
| 0x0068         | SC MCU_LDO_CTRL      | Low-dropout (LDO) control register                               | <a href="#">3-83</a> |
| 0x0080         | SC_GEN0              | System common register 0                                         | <a href="#">3-84</a> |
| 0x0084         | SC_GEN1              | System common register 1                                         | <a href="#">3-84</a> |
| 0x0088         | SC_GEN2              | System common register 2                                         | <a href="#">3-84</a> |



| Offset Address | Register        | Description                           | Page |
|----------------|-----------------|---------------------------------------|------|
| 0x008C         | SC_GEN3         | System common register 3              | 3-85 |
| 0x0090         | SC_GEN4         | System common register 4              | 3-85 |
| 0x0094         | SC_GEN5         | System common register 5              | 3-85 |
| 0x0098         | SC_GEN6         | System common register 6              | 3-86 |
| 0x009C         | SC_GEN7         | System common register 7              | 3-86 |
| 0x00A0         | SC_GEN8         | System common register 8              | 3-86 |
| 0x00A4         | SC_GEN9         | System common register 9              | 3-87 |
| 0x00A8         | SC_GEN10        | System common register 10             | 3-87 |
| 0x00AC         | SC_GEN11        | System common register 11             | 3-87 |
| 0x00B0         | SC_GEN12        | System common register 12             | 3-88 |
| 0x00B4         | SC_GEN13        | System common register 13             | 3-88 |
| 0x00B8         | SC_GEN14        | System common register 14             | 3-88 |
| 0x00BC         | SC_GEN15        | System common register 15             | 3-89 |
| 0x00C0         | SC_GEN16        | System common register 16             | 3-89 |
| 0x00C4         | SC_GEN17        | System common register 17             | 3-89 |
| 0x00C8         | SC_GEN18        | System common register 18             | 3-90 |
| 0x00CC         | SC_GEN19        | System common register 19             | 3-90 |
| 0x00D0         | SC_GEN20        | System common register 20             | 3-90 |
| 0x00D4         | SC_GEN21        | System common register 21             | 3-91 |
| 0x00D8         | SC_GEN22        | System common register 22             | 3-91 |
| 0x00DC         | SC_GEN23        | System common register 23             | 3-91 |
| 0x00E0         | SC_GEN24        | System common register 24             | 3-92 |
| 0x00E4         | SC_GEN25        | System common register 25             | 3-92 |
| 0x00E8         | SC_GEN26        | System common register 26             | 3-93 |
| 0x00EC         | SC_GEN27        | System common register 27             | 3-93 |
| 0x00F0         | SC_GEN28        | System common register 28             | 3-93 |
| 0x00F4         | SC_GEN29        | System common register 29             | 3-94 |
| 0x00F8         | SC_GEN30        | System common register 30             | 3-94 |
| 0x00FC         | SC_GEN31        | System common register 31             | 3-94 |
| 0x0100         | SC_GPIO_OD_CTRL | GPIO open drain (OD) control register | 3-95 |



| Offset Address | Register  | Description                       | Page                  |
|----------------|-----------|-----------------------------------|-----------------------|
| 0x020C         | SC_LOCKEN | Write protection control register | <a href="#">3-95</a>  |
| 0x0EE0         | SC_SYSID  | Chip ID register                  | <a href="#">3-96</a>  |
| 0x0F00         | SC_GEN32  | System common register 32         | <a href="#">3-96</a>  |
| 0x0F04         | SC_GEN33  | System common register 33         | <a href="#">3-97</a>  |
| 0x0F08         | SC_GEN34  | System common register 34         | <a href="#">3-97</a>  |
| 0x0F0C         | SC_GEN35  | System common register 35         | <a href="#">3-98</a>  |
| 0x0F10         | SC_GEN36  | System common register 36         | <a href="#">3-98</a>  |
| 0x0F14         | SC_GEN37  | System common register 37         | <a href="#">3-98</a>  |
| 0x0F18         | SC_GEN38  | System common register 38         | <a href="#">3-99</a>  |
| 0x0F1C         | SC_GEN39  | System common register 39         | <a href="#">3-99</a>  |
| 0x0F20         | SC_GEN40  | System common register 40         | <a href="#">3-99</a>  |
| 0x0F24         | SC_GEN41  | System common register 41         | <a href="#">3-100</a> |
| 0x0F28         | SC_GEN42  | System common register 42         | <a href="#">3-100</a> |
| 0x0F2C         | SC_GEN43  | System common register 43         | <a href="#">3-100</a> |
| 0x0F30         | SC_GEN44  | System common register 44         | <a href="#">3-101</a> |
| 0x0F34         | SC_GEN45  | System common register 45         | <a href="#">3-101</a> |
| 0x0F38         | SC_GEN46  | System common register 46         | <a href="#">3-101</a> |
| 0x0F3C         | SC_GEN47  | System common register 47         | <a href="#">3-102</a> |
| 0x0F40         | SC_GEN48  | System common register 48         | <a href="#">3-102</a> |
| 0x0F44         | SC_GEN49  | System common register 49         | <a href="#">3-102</a> |
| 0x0F48         | SC_GEN50  | System common register 50         | <a href="#">3-103</a> |
| 0x0F4C         | SC_GEN51  | System common register 51         | <a href="#">3-103</a> |
| 0x0F50         | SC_GEN52  | System common register 52         | <a href="#">3-103</a> |
| 0x0F54         | SC_GEN53  | System common register 53         | <a href="#">3-104</a> |
| 0x0F58         | SC_GEN54  | System common register 54         | <a href="#">3-104</a> |
| 0x0F5C         | SC_GEN55  | System common register 55         | <a href="#">3-104</a> |
| 0x0F60         | SC_GEN56  | System common register 56         | <a href="#">3-105</a> |
| 0x0F64         | SC_GEN57  | System common register 57         | <a href="#">3-105</a> |
| 0x0F68         | SC_GEN58  | System common register 58         | <a href="#">3-105</a> |
| 0x0F6C         | SC_GEN59  | System common register 59         | <a href="#">3-106</a> |



| Offset Address | Register | Description               | Page                  |
|----------------|----------|---------------------------|-----------------------|
| 0x0F70         | SC_GEN60 | System common register 60 | <a href="#">3-106</a> |
| 0x0F74         | SC_GEN61 | System common register 61 | <a href="#">3-106</a> |
| 0x0F78         | SC_GEN62 | System common register 62 | <a href="#">3-107</a> |
| 0x0F7C         | SC_GEN63 | System common register 63 | <a href="#">3-107</a> |

### 3.4.5 Register Description

#### SC\_CTRL

SC\_CTRL is a system control register. It is used to specify the operations to be performed by the system.

|         | Offset Address                                                                                      | Register Name | Total Reset Value                                                                                  |
|---------|-----------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------------------------------|
|         | 0x0000                                                                                              | SC_CTRL       | 0x0000_0200                                                                                        |
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 |               |                                                                                                    |
| Name    |                                                                                                     | reserved      | remapstat<br>remapclear<br>reserved<br>mcu_bus_clk_div<br>mcu_bus_clk_sele_stat<br>mcu_bus_clk_sel |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 1 0   0 0 0 0   0 0 0 0                       |               |                                                                                                    |
| Bits    | Access                                                                                              | Name          | Description                                                                                        |
| [31:10] | RW                                                                                                  | reserved      | Reserved<br>Reading this field returns 0 and writing to this field has no effect.                  |
| [9]     | RO                                                                                                  | remapstat     | Address remap status<br>0: remap clear<br>1: remap                                                 |
| [8]     | RW                                                                                                  | remapclear    | Address remap clear<br>0: not cleared<br>1: cleared                                                |
| [7:6]   | RW                                                                                                  | reserved      | Reserved<br>Reading this field returns 0 and writing this field has no effect.                     |



|       |    |                       |                                                                                                                             |
|-------|----|-----------------------|-----------------------------------------------------------------------------------------------------------------------------|
| [5:4] | RW | mcu_bus_clk_div       | MCU bus clock mcu_bus_clk frequency divider<br>00: divided by 1<br>01: divided by 2<br>10: divided by 3<br>11: divided by 4 |
| [3:2] | RO | mcu_bus_clk_sele_stat | MCU bus clock status<br>00: 24 MHz<br>01: 200 MHz<br>10: 100 kHz<br>11: reserved                                            |
| [1:0] | RW | mcu_bus_clk_sel       | MCU bus clock select<br>00: 24 MHz<br>01: 200 MHz<br>10: 100 kHz<br>11: reserved                                            |

SC SYSRES

**SC\_SYSRES** is a system status register. When a value is written to this register, the system controller sends a system soft reset request to the reset module. Then the reset module resets the system.

## **SC\_LOW\_POWER\_CTRL**

SC LOW POWER CTRL is a low-power control register.



|         | Offset Address                                                                                      | Register Name       | Total Reset Value                                                                                                                                                          |
|---------|-----------------------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | 0x0040                                                                                              | SC_LOW_POWER_CTRL   | 0x0000_0402                                                                                                                                                                |
| Name    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | reserved            | rng_mcu_flag<br>core_pwr_active<br>bus_core_pd_idleack<br>bus_core_pd_idle<br>bus_core_pd_idlereq<br>reserved<br>mcu_lp_subsys_iso<br>reserved<br>stb_poweroff<br>reserved |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 1 0 0   0 0 0 0   0 0 1 0                       |                     |                                                                                                                                                                            |
| Bits    | Access                                                                                              | Name                | Description                                                                                                                                                                |
| [31:11] | RO                                                                                                  | reserved            | Reserved                                                                                                                                                                   |
| [10]    | RO                                                                                                  | rng_mcu_flag        | Whether the random numbers of the random number generator (RNG) in the always-on area are latched<br>0x0: no<br>0x1: yes                                                   |
| [9]     | RO                                                                                                  | core_pwr_active     | Whether the MCU has accessed the powered-off core area<br>0: no<br>1: yes                                                                                                  |
| [8]     | RO                                                                                                  | bus_core_pd_idleack | Power-down acknowledgement                                                                                                                                                 |
| [7]     | RO                                                                                                  | bus_core_pd_idle    | Power-down completion                                                                                                                                                      |
| [6]     | RW                                                                                                  | bus_core_pd_idlereq | Power-down request                                                                                                                                                         |
| [5:4]   | RW                                                                                                  | reserved            | Reserved                                                                                                                                                                   |
| [3]     | RW                                                                                                  | mcu_lp_subsys_iso   | Isolation area control<br>0: disabled. That is, signals are not isolated.<br>1: enabled. That is, signals are isolated.                                                    |
| [2]     | RW                                                                                                  | reserved            | Reserved                                                                                                                                                                   |
| [1]     | RW                                                                                                  | stb_poweroff        | Polarity of the STANDBY_PWROFF pin<br>0: low-level output<br>1: high-level output                                                                                          |
| [0]     | RW                                                                                                  | reserved            | Reserved                                                                                                                                                                   |



## SC\_IO\_REUSE\_SEL

SC\_IO\_REUSE\_SEL is an MCU subsystem pin multiplexing control register.

| Offset Address |          |                      |    |    |                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    | Register Name   |                     |                      |                     |                     |                     |          |                     |                    |          |              |          | Total Reset Value |               |          |               |              |          |                   |                   |   |  |  |  |
|----------------|----------|----------------------|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|-----------------|---------------------|----------------------|---------------------|---------------------|---------------------|----------|---------------------|--------------------|----------|--------------|----------|-------------------|---------------|----------|---------------|--------------|----------|-------------------|-------------------|---|--|--|--|
| 0x0044         |          |                      |    |    |                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    | SC_IO_REUSE_SEL |                     |                      |                     |                     |                     |          |                     |                    |          |              |          | 0x0038_0000       |               |          |               |              |          |                   |                   |   |  |  |  |
| Bit            | 31       | 30                   | 29 | 28 | 27                                                                                                                                                                                                                                                                                                              | 26 | 25 | 24 | 23 | 22 | 21 | 20              | 19                  | 18                   | 17                  | 16                  | 15                  | 14       | 13                  | 12                 | 11       | 10           | 9        | 8                 | 7             | 6        | 5             | 4            | 3        | 2                 | 1                 | 0 |  |  |  |
| Name           | reserved |                      |    |    |                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |                 | sim0_det_padctrl_PD | sim0_data_padctrl_PD | sim0_clk_padctrl_PD | sim0_clk_padctrl_DS | sim0_clk_padctrl_SR | reserved | led_data_padctrl_PD | led_clk_padctrl_PD | reserved | stb_gpio_sel | reserved | ir_gpio_sel       | csn0_gpio_sel | reserved | data_gpio_sel | clk_gpio_sel | reserved | uart_txd_gpio_sel | uart_rxd_gpio_sel |   |  |  |  |
| Reset          | 0        | 0                    | 0  | 0  | 0                                                                                                                                                                                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 1  | 1               | 1                   | 0                    | 0                   | 0                   | 0                   | 0        | 0                   | 0                  | 0        | 0            | 0        | 0                 | 0             | 0        | 0             | 0            | 0        | 0                 |                   |   |  |  |  |
| Bits           | Access   | Name                 |    |    | Description                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [31:25]        | RW       | reserved             |    |    | Reserved                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [24]           | RW       | sim0_det_padctrl_PD  |    |    | SIM0_DET pull-down control enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                  |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [23]           | RW       | sim0_data_padctrl_PD |    |    | SIM0_DATA pull-down control enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                 |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [22]           | RW       | sim0_clk_padctrl_PD  |    |    | SIM0_CLK pull-down control enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                  |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [21:20]        | RW       | sim0_clk_padctrl_DS  |    |    | SIM0_CLK drive current<br>00: 4 mA<br>01: 3 mA<br>10: 2 mA<br>11: 1 mA<br><br>When this pin is used as the SIM0_CLK function, the value 01 is recommended in OD output mode, and the value 10 is recommended in CMOS output mode.<br><br>When this pin is used as other functions, the value 11 is recommended. |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |
| [19]           | RW       | sim0_clk_padctrl_SR  |    |    | SIM0_CLK SR control enable<br>0: enabled<br>1: disabled (recommended)                                                                                                                                                                                                                                           |    |    |    |    |    |    |                 |                     |                      |                     |                     |                     |          |                     |                    |          |              |          |                   |               |          |               |              |          |                   |                   |   |  |  |  |



|         |    |                     |                                                                                                                        |
|---------|----|---------------------|------------------------------------------------------------------------------------------------------------------------|
| [18]    | RW | reserved            | Reserved                                                                                                               |
| [17]    | RW | led_data_padctrl_PD | LED_DATA pull-down control enable<br>0: disabled<br>1: enabled<br>This bit must be set to 1 for the QFP216 32-bit DDR. |
| [16]    | RW | led_clk_padctrl_PD  | LED_CLK pull-down control enable<br>0: disabled<br>1: enabled<br>This bit must be set to 1 for the QFP216 32-bit DDR.  |
| [15:14] | RW | reserved            | Reserved                                                                                                               |
| [13]    | RW | stb_gpio_sel        | Multiplexing control for the STANDBY_PWROFF pin<br>0: STANDBY_PWROFF<br>1: GPIO5_0                                     |
| [12:11] | RW | reserved            | Reserved                                                                                                               |
| [10]    | RW | ir_gpio_sel         | Multiplexing control for the IR_IN pin<br>0: IR_IN<br>1: GPIO5_1                                                       |
| [9:8]   | RW | csn0_gpio_sel       | Multiplexing control for the LED_CSN0 pin<br>00: LED_KEY0<br>01: GPIO5_2<br>10: RSTN_IN                                |
| [7:6]   | RW | reserved            | Reserved                                                                                                               |
| [5]     | RW | data_gpio_sel       | Multiplexing control for the LED_DATA pin<br>0: GPIO5_5<br>1: LED DATA                                                 |
| [4]     | RW | clk_gpio_sel        | Multiplexing control for the LED_CLK pin<br>0: GPIO5_6<br>1: LED CLK                                                   |
| [3:2]   | RW | reserved            | Reserved                                                                                                               |
| [1]     | RW | uart_txd_gpio_sel   | Multiplexing control for the UART0_TXD pin<br>0: UART0_TXD<br>1: UART1_TXD                                             |
| [0]     | RW | uart_rxd_gpio_sel   | Multiplexing control for the UART0_RXD pin<br>0: UART0_RXD<br>1: UART1_RXD                                             |



## SC\_CLKGATE\_SRST\_CTRL

SC\_CLKGATE\_SRST\_CTRL is an MCU internal module clock gating and soft reset control register.

|         |      | Offset Address 0x0048 |    |                  |    |    |    |                                                            |    |    |    |    |    |    |    |    |    | Register Name SC_CLKGATE_SRST_CTRL |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value 0x0001_1151 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------|------|-----------------------|----|------------------|----|----|----|------------------------------------------------------------|----|----|----|----|----|----|----|----|----|------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit     | Name | 31                    | 30 | 29               | 28 | 27 | 26 | 25                                                         | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset   |      | 0                     | 0  | 0                | 0  | 0  | 0  | 0                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0                                  | 0  | 1  | 0  | 0  | 0  | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|         |      | reserved              |    |                  |    |    |    |                                                            |    |    |    |    |    |    |    |    |    | uart_srst_req                      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | reserved                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits    |      | Access                |    | Name             |    |    |    | Description                                                |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:29] |      | RW                    |    | reserved         |    |    |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [28]    |      | RW                    |    | pd_rst_req       |    |    |    | Power-down reset request<br>0: not reset<br>1: reset       |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [27:14] |      | RW                    |    | reserved         |    |    |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [13]    |      | RW                    |    | uart_srst_req    |    |    |    | UART soft reset<br>0: not reset<br>1: reset                |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [12]    |      | RW                    |    | uart_cken        |    |    |    | UART clock gating<br>0: disabled<br>1: enabled             |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [11:10] |      | RW                    |    | reserved         |    |    |    | Reserved                                                   |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [9]     |      | RW                    |    | led_srst_req     |    |    |    | LED module soft reset<br>0: not reset<br>1: reset          |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [8]     |      | RW                    |    | led_cken         |    |    |    | LEDC clock gating<br>0: disabled<br>1: enabled             |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [7]     |      | RW                    |    | timer01_srst_req |    |    |    | Timer 0 and timer 1 soft reset<br>0: not reset<br>1: reset |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



|       |    |              |                                                               |
|-------|----|--------------|---------------------------------------------------------------|
| [6]   | RW | timer01_cken | Timer 0 and timer 1 clock gating<br>0: disabled<br>1: enabled |
| [5]   | RW | ir_srst_req  | IR module soft reset<br>0: not reset<br>1: reset              |
| [4]   | RW | ir_cken      | IR clock gating<br>0: disabled<br>1: enabled                  |
| [3:2] | RW | reserved     | Reserved                                                      |
| [1]   | RW | mce_srst_req | MCU soft reset<br>0: not reset<br>1: reset                    |
| [0]   | RW | mce_cken     | MCU clock gating<br>0: disabled<br>1: enabled                 |

## SC\_WDG\_RST\_CTRL

SC\_WDG\_RST\_CTRL is a software-controlled WDG reset register.

|        | Offset Address<br>0x0050 |              |    |    |                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>SC_WDG_RST_CTRL |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |              |   |   |   |
|--------|--------------------------|--------------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|--------------|---|---|---|
| Bit    | 31                       | 30           | 29 | 28 | 27                                                                                                                                                                                                    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3            | 2 | 1 | 0 |
| Name   | reserved                 |              |    |    |                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |                                  |   |   |   | wdg_rst_ctrl |   |   |   |
| Reset  | 0                        | 0            | 0  | 0  | 0                                                                                                                                                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0            | 0 |   |   |
| Bits   | Access                   | Name         |    |    | Description                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |                                  |   |   |   |              |   |   |   |
| [31:1] | RW                       | reserved     |    |    | Reserved                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |                                  |   |   |   |              |   |   |   |
| [0]    | RW                       | wdg_rst_ctrl |    |    | WDG_RST reset signal (controlled by software).<br>0: not reset<br>1: enable WDG_RST software control. When timer 0 or timer 1 generates an interrupt, a reset signal is sent through the WDG_RST pin. |    |    |    |    |    |    |    |    |    |    |    |                                  |    |    |    |    |    |   |   |                                  |   |   |   |              |   |   |   |



## SC\_DDRPHY\_LP\_EN

SC\_DDRPHY\_LP\_EN is a DDR PHY low-power control register.

|        | Offset Address |              |    |                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |   |   |   |   |   |  |              |
|--------|----------------|--------------|----|-------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|---|---|---|---|---|--|--------------|
| Bit    | 31             | 30           | 29 | 28                                                                                                    | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |              |
| Name   | reserved       |              |    |                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |  | ddrphy_lp_en |
| Reset  | 0              | 0            | 0  | 0                                                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 |   |   |  |              |
| Bits   | Access         | Name         |    | Description                                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |  |              |
| [31:2] | RW             | reserved     |    | Reserved                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |  |              |
| [1:0]  | RW             | ddrphy_lp_en |    | DDR PHY mode<br>01: The DDR PHY is in normal mode.<br>Other values: The DDR PHY is in retention mode. |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |  |              |

## SC MCU\_HPM\_CTRL

SC\_MCU\_HPM\_CTRL is an HPM control register.

|        | Offset Address |                 |    |                                                                            |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |   |            |             |   |   |
|--------|----------------|-----------------|----|----------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|---|------------|-------------|---|---|
| Bit    | 31             | 30              | 29 | 28                                                                         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3          | 2           | 1 | 0 |
| Name   | reserved       |                 |    |                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   | mcu_hpm_en | mcu_hpm_div |   |   |
| Reset  | 0              | 0               | 0  | 0                                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0          |             |   |   |
| Bits   | Access         | Name            |    | Description                                                                |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |            |             |   |   |
| [31:8] | RW             | reserved        |    | Reserved                                                                   |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |            |             |   |   |
| [7]    | RW             | mcu_hpm_rst_req |    | HPM reset request control<br>0: no reset request<br>1: valid reset request |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |            |             |   |   |



|       |    |             |                                            |
|-------|----|-------------|--------------------------------------------|
| [6]   | RW | mcu_hpm_en  | HPM enable<br>0: disabled<br>1: enabled    |
| [5:0] | RW | mcu_hpm_div | Frequency divider of the HPM working clock |

## SC MCU HPM STAT

SC MCU HPM STAT is an HPM status register.

SC MCU LDO CTRL

SC MCU LDO CTRL is an LDO control register.

| Offset Address |          |          |    |    |             |    |    | Register Name   |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------|----|----|-----------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|--------------|---|---|---|---|---|---|
| 0x0068         |          |          |    |    |             |    |    | SC MCU LDO_CTRL |    |    |    |    |    |    |    | 0x0000_0008       |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27          | 26 | 25 | 24              | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6            | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |             |    |    |                 |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   | mcu_ldo_vset |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0           | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0            | 1 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description |    |    |                 |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |
| [31:4]         | RW       | reserved |    |    | Reserved    |    |    |                 |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |              |   |   |   |   |   |   |



[3:0] RW mcu\_ldo\_vset mcu\_ldo\_vset value

**SC\_GEN0**

SC\_GEN0 is system common register 0.

SC GEN1

SC\_GEN1 is system common register 1.

| Offset Address |         |         |    |                                                              |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|---------|---------|----|--------------------------------------------------------------|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0084         |         |         |    |                                                              |    |    |    | SC_GEN1       |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30      | 29 | 28                                                           | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen1 |         |    |                                                              |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0       | 0       | 0  | 0                                                            | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access  | Name    |    | Description                                                  |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW      | sc_gen1 |    | This register is used to save the system status as required. |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN2

SC\_GEN2 is system common register 2.



| Offset Address |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|--------|---------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0088         |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN2       |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31     | 30      | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen2 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0       | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access | Name    |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen2 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN3

SC\_GEN3 is system common register 3.

| Offset Address |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|--------|---------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x008C         |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN3       |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31     | 30      | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen3 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0       | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access | Name    |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen3 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN4

SC\_GEN4 is system common register 4.

| Offset Address |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|--------|---------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0090         |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN4       |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31     | 30      | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           |        |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen4 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0       | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access | Name    |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen4 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN5

SC\_GEN5 is system common register 5.



| Offset Address |                                                                                                                                                                                                                                                                             |         | Register Name |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              | Total Reset Value |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------------------------------------------------|-------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x0094                                                                                                                                                                                                                                                                      |         |               | SC_GEN5 |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   | 0x0000_0000 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | sc_gen5                                                                                                                                                                                                                                                                     |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                                                                                                                                                                                                                      | Name    |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | Description                                                  |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:0]         | RW                                                                                                                                                                                                                                                                          | sc_gen5 |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | This register is used to save the system status as required. |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN6

SC\_GEN6 is system common register 6.

| Offset Address |                                                                                                                                                                                                                                                                                                 |         | Register Name |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              | Total Reset Value |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------------------------------------------------|-------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x0098                                                                                                                                                                                                                                                                                          |         |               | SC_GEN6 |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   | 0x0000_0000 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | sc_gen6                                                                                                                                                                                                                                                                                         |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                                                                                                                                                                                                                                          | Name    |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | Description                                                  |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:0]         | RW                                                                                                                                                                                                                                                                                              | sc_gen6 |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | This register is used to save the system status as required. |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN7

SC\_GEN7 is system common register 7.

| Offset Address |                                                                                                                                                                                                                                                                                                 |         | Register Name |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              | Total Reset Value |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------|---------|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------------------------------------------------------|-------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x009C                                                                                                                                                                                                                                                                                          |         |               | SC_GEN7 |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   | 0x0000_0000 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | sc_gen7                                                                                                                                                                                                                                                                                         |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |         |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  |                                                              |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                                                                                                                                                                                                                                          | Name    |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | Description                                                  |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:0]         | RW                                                                                                                                                                                                                                                                                              | sc_gen7 |               |         |  |  |  |  |  |  |  |  |  |  |  |  |  | This register is used to save the system status as required. |                   |             |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN8

SC\_GEN8 is system common register 8.



| Offset Address |         |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|---------|---------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00A0         |         |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN8       |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30      | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen8 |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen8 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0       | 0       | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access  | Name    |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW      | sc_gen8 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN9

SC\_GEN9 is system common register 9.

| Offset Address |         |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|---------|---------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00A4         |         |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN9       |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30      | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen9 |         |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen9 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0       | 0       | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access  | Name    |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW      | sc_gen9 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN10

SC\_GEN10 is system common register 10.

| Offset Address |          |          |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00A8         |          |          |    |    |    |                                                              |    |    |    |    |    |    |    |    |    | SC_GEN10      |          |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen10 |          |    |    |    |                                                              |    |    |    |    |    |    |    |    |    |               | sc_gen10 |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name     |    |    |    | Description                                                  |    |    |    |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen10 |    |    |    | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN11

SC\_GEN11 is system common register 11.



| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00AC         |          |          | SC_GEN11      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen11 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen11 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN12

SC\_GEN12 is system common register 12.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00B0         |          |          | SC_GEN12      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen12 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen12 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN13

SC\_GEN13 is system common register 13.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00B4         |          |          | SC_GEN13      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen13 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen13 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN14

SC\_GEN14 is system common register 14.



| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00B8         |          |          | SC_GEN14      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen14 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen14 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN15

SC\_GEN15 is system common register 15.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00BC         |          |          | SC_GEN15      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen15 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen15 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN16

SC\_GEN16 is system common register 16.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00C0         |          |          | SC_GEN16      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen16 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen16 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN17

SC\_GEN17 is system common register 17.



| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00C4         |          |          | SC_GEN17      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen17 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen17 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN18

SC\_GEN18 is system common register 18.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00C8         |          |          | SC_GEN18      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen18 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen18 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN19

SC\_GEN19 is system common register 19.

| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00CC         |          |          | SC_GEN19      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen19 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen19 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN20

SC\_GEN20 is system common register 20.



SC GEN21

SC\_GEN21 is system common register 21.

| Offset Address |          |          |    |    |                                                              |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|--------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00D4         |          |          |    |    |                                                              |    |    | SC_GEN21      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                           | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen21 |          |    |    |                                                              |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                            | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                  |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen21 |    |    | This register is used to save the system status as required. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN22

SC\_GEN22 is system common register 22.

SC GEN23

SC GEN23 is system common register 23.



| Offset Address |          |          | Register Name |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00DC         |          |          | SC_GEN23      |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen23 |          |               |                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen23 |               | This register is used to save the system status as required. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN24

SC\_GEN24 is system common register 24.

| Offset Address |          |          | Register Name |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00E0         |          |          | SC_GEN24      |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen24 |          |               |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen24 |               | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |

## SC\_GEN25

SC\_GEN25 is system common register 25.

| Offset Address |          |          | Register Name |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|---------------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00E4         |          |          | SC_GEN25      |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29            | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13                | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen25 |          |               |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0             | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |               | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen25 |               | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |   |   |   |   |   |   |   |   |   |   |



## SC\_GEN26

SC\_GEN26 is system common register 26.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00E8         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN26      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen26 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen26 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN27

SC\_GEN27 is system common register 27.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00EC         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN27      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen27 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen27 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN28

SC\_GEN28 is system common register 28.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x00F0         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN28      |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen28 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen28 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |



SC\_GEN29

SC\_GEN29 is system common register 29.

| Offset Address |          |          |    | Register Name |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|---------------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00F4         |          |          |    | SC_GEN29      |                                                                                                             |    |    |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28            | 27                                                                                                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen29 |          |    |               |                                                                                                             |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0             | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |               | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen29 |    |               | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC\_GEN30

SC\_GEN30 is system common register 30.

SC\_GEN31

SC\_GEN31 is system common register 31.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x00FC         |          |          |    |    |                                                                                                             |    |    | SC_GEN31      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen31 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen31 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



## SC\_GPIO\_OD\_CTRL

SC\_GPIO\_OD\_CTRL is a GPIO OD control register.

|        | Offset Address 0x0100 |                |    |                                               |    |    |    |    |    |    |    |    |    |    |    |    | Register Name SC_GPIO_OD_CTRL |    |    |    |    |    |   |   | Total Reset Value 0x0000_0000 |   |   |   |   |   |   |   |
|--------|-----------------------|----------------|----|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|----|----|----|----|----|---|---|-------------------------------|---|---|---|---|---|---|---|
| Bit    | 31                    | 30             | 29 | 28                                            | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | reserved              |                |    |                                               |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| Reset  | 0                     | 0              | 0  | 0                                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                             | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits   | Access                | Name           |    | Description                                   |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [31:7] | RW                    | reserved       |    | Reserved                                      |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [6]    | RW                    | gpio5_6_od_sel |    | Whether GPIO5 bit[6] is OD<br>0: no<br>1: yes |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [5]    | RW                    | gpio5_5_od_sel |    | Whether GPIO5 bit[5] is OD<br>0: no<br>1: yes |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [4:3]  | RW                    | reserved       |    | Reserved                                      |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [2]    | RW                    | gpio5_2_od_sel |    | Whether GPIO5 bit[2] is OD<br>0: no<br>1: yes |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [1]    | RW                    | gpio5_1_od_sel |    | Whether GPIO5 bit[1] is OD<br>0: no<br>1: yes |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [0]    | RW                    | gpio5_0_od_sel |    | Whether GPIO5 bit[0] is OD<br>0: no<br>1: yes |    |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |

## SC\_LOCKEN

SC\_LOCKEN is a write protection control register. This register provides the write protection mechanism for key registers (SC\_CTRL and SC\_SYSRES) of the system controller.



| Offset Address |                                                                               |           |  |  |  |  |  |  |  |  |  |  |  |  |  | Register Name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-------------------------------------------------------------------------------|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x020C                                                                        |           |  |  |  |  |  |  |  |  |  |  |  |  |  | SC_LOCKEN     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  | 0x756E_4C4F       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | sc_locken                                                                     |           |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 1 1 1   0 1 0 1   0 1 1 0   1 1 1 0   0 1 0 0   1 1 0 0   0 1 0 0   1 1 1 1 |           |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                        | Name      |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:0]         | RW                                                                            | sc_locken |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Write protection indicator for key system registers. The configuration is as follows:<br><br>When the value 0x4F50_454E is written to SC_LOCKEN, the write protection function of the preceding key registers is enabled. The attributes of the key registers are changed to writable, that is, these registers can be written.<br><br>When any value except 0x4F50_454E is written to SC_LOCKEN, the attributes of the key register are changed to read-only. In this case, writing to these registers has no effect.<br><br>You can check whether the key registers are write-protected by reading SC_LOCKEN. For example, if the value 0x756E_4C4F is returned after SC_LOCKEN is read, the key registers are not write-protected and writing to these registers has no effect. If the value 0x4C4F_434B is returned, write protection is enabled, and writing to these registers has no effect.<br><br>The reset value of SC_LOCKEN is 0x756E_4C4F, indicating that the key registers are not write-protected. |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SC\_SYSID

SC\_SYSID is a chip ID register.

| Offset Address |                                                                               |          |  |  |  |  |  |  |  |  |  |  |  |  |  | Register Name |                           |  |  |  |  |  |  | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-------------------------------------------------------------------------------|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|---------------|---------------------------|--|--|--|--|--|--|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x0EE0                                                                        |          |  |  |  |  |  |  |  |  |  |  |  |  |  | SC_SYSID      |                           |  |  |  |  |  |  | 0x3796_0100       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | sc_sysid                                                                      |          |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                           |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 1 1   0 1 1 1   1 0 0 1   1 0 0 0   0 0 0 0   0 0 0 1   0 0 0 0   0 0 0 0 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                           |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                        | Name     |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Description               |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:0]         | RO                                                                            | sc_sysid |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Major release of the chip |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN32

SC\_GEN32 is system common register 32.



| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F00         |          |          |    |    |                                                                                                             |    |    | SC_GEN32      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen32 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen32 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN33

SC\_GEN33 is system common register 33.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F04         |          |          |    |    |                                                                                                             |    |    | SC_GEN33      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen33 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen33 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN34

SC\_GEN34 is system common register 34.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F08         |          |          |    |    |                                                                                                             |    |    | SC_GEN34      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen34 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen34 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



## SC\_GEN35

SC\_GEN35 is system common register 35.

| Offset Address |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F0C         |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN35      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen35 |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen35 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN36

SC\_GEN36 is system common register 36.

| Offset Address |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F10         |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN36      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen36 |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen36 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN37

SC\_GEN37 is system common register 37.

| Offset Address |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F14         |          |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN37      |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen37 |          |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen37 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |



SC\_GEN38

SC\_GEN38 is system common register 38.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F18         |          |          |    |    |                                                                                                             |    |    | SC_GEN38      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen38 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen38 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC\_GEN39

SC\_GEN39 is system common register 39.

SC\_GEN40

SC\_GEN40 is system common register 40.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F20         |          |          |    |    |                                                                                                             |    |    | SC_GEN40      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen40 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen40 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



## SC\_GEN41

SC\_GEN41 is system common register 41.

|        | Offset Address |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F24         |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN41      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26                                                                                                          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen41       |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen41 |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN42

SC\_GEN42 is system common register 42.

|        | Offset Address |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F28         |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN42      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26                                                                                                          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen42       |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen42 |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN43

SC\_GEN43 is system common register 43.

|        | Offset Address |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|-------------|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F2C         |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    | SC_GEN43      |    |    |    |    |    |   |   |   | 0x0000_0000 |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26                                                                                                          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen43       |          |    |    |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen43 |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |             |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |



SC\_GEN44

SC\_GEN44 is system common register 44.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F30         |          |          |    |    |                                                                                                             |    |    | SC_GEN44      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen44 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen44 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN45

SC GEN45 is system common register 45.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F34         |          |          |    |    |                                                                                                             |    |    | SC_GEN45      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen45 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen45 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC GEN46

SC\_GEN46 is system common register 46.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F38         |          |          |    |    |                                                                                                             |    |    | SC_GEN46      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen46 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen46 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



## SC\_GEN47

SC\_GEN47 is system common register 47.

|        | Offset Address |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |
|--------|----------------|----------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|
|        | 0x0F3C         |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | SC_GEN47      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |
| Bit    | 31             | 30       | 29                                                                                                          | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |
| Name   | sc_gen47       |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| Reset  | 0              | 0        | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |
| Bits   | Access         | Name     | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| [31:0] | RW             | sc_gen47 | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |

## SC\_GEN48

SC\_GEN48 is system common register 48.

|        | Offset Address |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |
|--------|----------------|----------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|
|        | 0x0F40         |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | SC_GEN48      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |
| Bit    | 31             | 30       | 29                                                                                                          | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |
| Name   | sc_gen48       |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| Reset  | 0              | 0        | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |
| Bits   | Access         | Name     | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| [31:0] | RW             | sc_gen48 | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |

## SC\_GEN49

SC\_GEN49 is system common register 49.

|        | Offset Address |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |
|--------|----------------|----------|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|
|        | 0x0F44         |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    | SC_GEN49      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| Bit    | 31             | 30       | 29                                                                                                          | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |
| Name   | sc_gen49       |          |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| Reset  | 0              | 0        | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |
| Bits   | Access         | Name     | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |
| [31:0] | RW             | sc_gen49 | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |



## SC\_GEN50

SC\_GEN50 is system common register 50.

| Offset Address |        |          | Register Name |          |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   | Total Reset Value |             |   |   |   |   |   |   |   |   |
|----------------|--------|----------|---------------|----------|-------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|-------------------|-------------|---|---|---|---|---|---|---|---|
| Bit            | 0x0F48 |          |               | SC_GEN50 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   | 0x0000_0000 |   |   |   |   |   |   |   |   |
| Name           |        |          |               | sc_gen50 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0        | 0             | 0        | 0                                                                                                           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access | Name     |               |          | Description                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen50 |               |          | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |

## SC\_GEN51

SC\_GEN51 is system common register 51.

| Offset Address |        |          | Register Name |          |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   | Total Reset Value |             |   |   |   |   |   |   |   |   |
|----------------|--------|----------|---------------|----------|-------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|-------------------|-------------|---|---|---|---|---|---|---|---|
| Bit            | 0x0F4C |          |               | SC_GEN51 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   | 0x0000_0000 |   |   |   |   |   |   |   |   |
| Name           |        |          |               | sc_gen51 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0        | 0             | 0        | 0                                                                                                           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access | Name     |               |          | Description                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen51 |               |          | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |

## SC\_GEN52

SC\_GEN52 is system common register 52.

| Offset Address |        |          | Register Name |          |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   | Total Reset Value |             |   |   |   |   |   |   |   |   |
|----------------|--------|----------|---------------|----------|-------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|-------------------|-------------|---|---|---|---|---|---|---|---|
| Bit            | 0x0F50 |          |               | SC_GEN52 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   | 0x0000_0000 |   |   |   |   |   |   |   |   |
| Name           |        |          |               | sc_gen52 |                                                                                                             |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0        | 0             | 0        | 0                                                                                                           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access | Name     |               |          | Description                                                                                                 |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | sc_gen52 |               |          | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |



## SC\_GEN53

SC\_GEN53 is system common register 53.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F54         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN53      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen53 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen53 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN54

SC\_GEN54 is system common register 54.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F58         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN54      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen54 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen54 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## SC\_GEN55

SC\_GEN55 is system common register 55.

| Offset Address |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0F5C         |          |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | SC_GEN55      |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen55 |          |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen55 |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |



## SC\_GEN56

SC\_GEN56 is system common register 56.

|        | Offset Address |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F60         |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | SC_GEN56      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                                                                          | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen56       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                                                                                           | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    |    |    |    |    |    |    |    |    |    |    | Description                                                                                                 |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen56 |    |    |    |    |    |    |    |    |    |    |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN57

SC\_GEN57 is system common register 57.

|        | Offset Address |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F64         |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | SC_GEN57      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                                                                          | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen57       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                                                                                           | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    |    |    |    |    |    |    |    |    |    |    | Description                                                                                                 |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen57 |    |    |    |    |    |    |    |    |    |    |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

## SC\_GEN58

SC\_GEN58 is system common register 58.

|        | Offset Address |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------------------------------------------------------------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0F68         |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             | SC_GEN58      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                                                                          | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Name   | sc_gen58       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                                                                             |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                                                                                           | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    |    |    |    |    |    |    |    |    |    |    |    | Description                                                                                                 |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| [31:0] | RW             | sc_gen58 |    |    |    |    |    |    |    |    |    |    |    |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |



SC\_GEN59

SC\_GEN59 is system common register 59.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F6C         |          |          |    |    |                                                                                                             |    |    | SC_GEN59      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen59 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen59 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

SC\_GEN60

SC\_GEN60 is system common register 60.

SC\_GEN61

SC\_GEN61 is system common register 61.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F74         |          |          |    |    |                                                                                                             |    |    | SC_GEN61      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen61 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen61 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



SC\_GEN62

SC\_GEN62 is system common register 62.

| Offset Address |          |          |    |    |                                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0F78         |          |          |    |    |                                                                                                             |    |    | SC_GEN62      |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | sc_gen62 |          |    |    |                                                                                                             |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    | Description                                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW       | sc_gen62 |    |    | This register is used to save the system status as required.<br>It is controlled by POR but not soft reset. |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**SC\_GEN63**

SC\_GEN63 is system common register 63.

## 3.5 Peripheral Controller

### 3.5.1 Overview

The peripheral controller controls peripherals, queries their status, and configures some functions of peripherals.

### 3.5.2 Features

The peripheral controller has the following features:

- Controls read and write operations on peripherals over the advanced peripheral bus (APB).
  - Controls some peripherals and queries their status.
  - Controls the software interrupts between CPUs.



### 3.5.3 Register Summary

Table 3-45 describes PERI\_CTRL registers.

**Table 3-45** Summary of PERI\_CTRL registers (base address: 0xF8A2\_0000)

| Offset Address | Register                    | Description                                                | Page                  |
|----------------|-----------------------------|------------------------------------------------------------|-----------------------|
| 0x0000         | START_MODE                  | System startup status query register                       | <a href="#">3-109</a> |
| 0x0008         | PERI_CTRL                   | Peripheral control register                                | <a href="#">3-110</a> |
| 0x000C         | CPU_STAT                    | A7 status query register                                   | <a href="#">3-112</a> |
| 0x00B4         | PERI_USB_RESUME_INT_MASK    | USB wakeup interrupt mask register                         | <a href="#">3-112</a> |
| 0x00B8         | PERI_USB_RESUME_INT_RAWSTAT | Raw USB wakeup interrupt status register                   | <a href="#">3-113</a> |
| 0x00BC         | PERI_USB_RESUME_INT_STAT    | USB wakeup interrupt status register                       | <a href="#">3-114</a> |
| 0x00C0         | PERI_INT_A9TOMCE            | A7-to-MCU software interrupt register                      | <a href="#">3-114</a> |
| 0x00E4         | PERI_INT_SWI0               | Software interrupt 0 register                              | <a href="#">3-115</a> |
| 0x00E8         | PERI_INT_SWI1               | Software interrupt 1 register                              | <a href="#">3-115</a> |
| 0x00EC         | PERI_INT_SWI2               | Software interrupt 2 register                              | <a href="#">3-116</a> |
| 0x00F0         | PERI_INT_SWI0_MASK          | Software interrupt 0 mask register                         | <a href="#">3-116</a> |
| 0x00F4         | PERI_INT_SWI1_MASK          | Software interrupt 1 mask register                         | <a href="#">3-117</a> |
| 0x00F8         | PERI_INT_SWI2_MASK          | Software interrupt 2 mask register                         | <a href="#">3-118</a> |
| 0x0110         | PERI_TIANLA_ADAC0           | ADAC configuration register 0                              | <a href="#">3-118</a> |
| 0x0114         | PERI_TIANLA_ADAC1           | ADAC configuration register 1                              | <a href="#">3-120</a> |
| 0x0118         | PERI_FEPHY                  | FE PHY configuration register                              | <a href="#">3-123</a> |
| 0x011C         | PERI_SD_LDO                 | SDIO0 LDO control register                                 | <a href="#">3-124</a> |
| 0x0120         | PERI_USB0                   | USB controller configuration register 0                    | <a href="#">3-125</a> |
| 0x0124         | PERI_USB1                   | USB PHY configuration register                             | <a href="#">3-127</a> |
| 0x0134         | PERI_USB5                   | USB 3.0 system controller 0                                | <a href="#">3-127</a> |
| 0x0138         | PERI_USB6                   | USB 3.0 physical coding sublayer (PCS) system controller 1 | <a href="#">3-129</a> |
| 0x013C         | PERI_USB7                   | USB 3.0 PHY system controller 0                            | <a href="#">3-129</a> |
| 0x0140         | PERI_USB8                   | USB 3.0 PHY system controller 1                            | <a href="#">3-130</a> |



| Offset Address | Register            | Description                                | Page                  |
|----------------|---------------------|--------------------------------------------|-----------------------|
| 0x0144         | PERI_USB9           | USB 3.0 PHY system controller 2            | <a href="#">3-132</a> |
| 0x0148         | PERI_USB10          | USB 3.0 PHY system controller 3            | <a href="#">3-133</a> |
| 0x0150         | PERI_USB12          | USB 3.0 system controller 2                | <a href="#">3-134</a> |
| 0x0154         | PERI_USB13          | USB controller configuration register 1    | <a href="#">3-135</a> |
| 0x0158         | PERI_USB14          | USB PHY configuration register 1           | <a href="#">3-136</a> |
| 0x01E0         | CHIPSET_INFO        | Chip information register                  | <a href="#">3-137</a> |
| 0x01F0         | PERI_SW_SET         | Software flag configuration register       | <a href="#">3-137</a> |
| 0x083C         | PERI_SIM_OD_CTRL    | SCI pin output OD mode control register    | <a href="#">3-137</a> |
| 0x0844         | PERI_FEPHY_LDO_CTRL | FE PHY LDO control register                | <a href="#">3-138</a> |
| 0x880          | PERI_CPU_A7_CFG     | CPU control register                       | <a href="#">3-138</a> |
| 0x884          | PERI_CPU_A7_STAT    | CPU status register                        | <a href="#">3-140</a> |
| 0x0890         | PERI_FE_OD_CTRL     | FE LED pin output OD mode control register | <a href="#">3-141</a> |

### 3.5.4 Register Description

#### START\_MODE

START\_MODE is a system startup status query register.

|         | Offset Address |          | Register Name        |             | Total Reset Value |    |          |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----------------|----------|----------------------|-------------|-------------------|----|----------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|         | 0x0000         |          | START_MODE           |             | 0x0140_0700       |    |          |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit     | 31             | 30       | 29                   | 28          | 27                | 26 | 25       | 24       | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved       |          | usb_boot_jtag_sel_in | reserved    | reserved          |    | boot_sel | reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset   | 0              | 0        | 0                    | 0           | 0                 | 0  | 1        | 0        | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access         | Name     |                      | Description |                   |    |          |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:25] | RO             | reserved |                      | Reserved    |                   |    |          |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



|         |    |             |                                                                                                                                                                                                                                                                                                         |
|---------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24]    | RO | usb_boot    | USB device burning boot enable<br>0: enabled<br>1: disabled                                                                                                                                                                                                                                             |
| [23]    | RO | jtag_sel_in | Multiplexing control indicator of JTAG pins<br>0: JTAG pin multiplexing is controlled by pin multiplexing registers. For detail, see the pin multiplexing section.<br>1: The JTAG pins are always used for JTAG functions.<br>JTAG pins include JTAG_TDI, JTAG_TCK, JTAG_TMS, JTAG_TDO, and JTAG_TRSTN. |
| [22:11] | RO | reserved    | Reserved                                                                                                                                                                                                                                                                                                |
| [10:9]  | RO | boot_sel    | Boot memory type<br>00: reserved<br>01: NAND flash<br>10: SD<br>11: eMMC                                                                                                                                                                                                                                |
| [8:0]   | RO | reserved    | Reserved                                                                                                                                                                                                                                                                                                |

## PERI\_CTRL

PERI\_CTRL is a peripheral control register.

|       | Offset Address |    |               |          |                  |          |             |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |             |                  |          | Total Reset Value   |                     |   |   |   |   |   |   |
|-------|----------------|----|---------------|----------|------------------|----------|-------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|-------------|------------------|----------|---------------------|---------------------|---|---|---|---|---|---|
|       | 0x0008         |    |               |          |                  |          |             |    |    |    |    |    |    |    |    |    | PERI_CTRL     |    |    |    |    |             |                  |          | 0x0400_0000         |                     |   |   |   |   |   |   |
| Bit   | 31             | 30 | 29            | 28       | 27               | 26       | 25          | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10          | 9                | 8        | 7                   | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | peri_jtag_sel  |    | clk_mhlrx_sel | reserved | usb3_ip_iso_ctrl | reserved |             |    |    |    |    |    |    |    |    |    |               |    |    |    |    | ssp0_cs_sel | usb2_ip_iso_ctrl | reserved | sdio0_card_det_mode | sdio1_card_det_mode |   |   |   |   |   |   |
| Reset | 0              | 0  | 0             | 0        | 0                | 1        | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0           | 0                | 0        | 0                   | 0                   | 0 | 0 | 0 | 0 |   |   |
| Bits  | Access         |    | Name          |          |                  |          | Description |    |    |    |    |    |    |    |    |    |               |    |    |    |    |             |                  |          |                     |                     |   |   |   |   |   |   |



|         |    |                     |                                                                                                                                                                  |
|---------|----|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | RW | peri_jtag_sel       | JTAG interface select when jtag_sel is 0<br>0: CPU JTAG<br>1: reserved<br>2: reserved<br>3: reserved<br>4: reserved<br>5: reserved<br>6: reserved<br>7: SOC JTAG |
| [28]    | RW | clk_mhlnx_sel       | HDMI MHLNX clock select<br>0: reduced clock path (this bit must be 0 when the frequency is 268.5 MHz)<br>1: original clock path                                  |
| [27]    | RW | reserved            | Reserved                                                                                                                                                         |
| [26]    | RW | usb3_ip_iso_ctrl    | USB3 PHY IP isolation control<br>0: not isolated<br>1: isolated                                                                                                  |
| [25:5]  | RW | reserved            | Reserved                                                                                                                                                         |
| [4]     | RW | ssp0_cs_sel         | SSP0 CS multiplexing control<br>0: SSP0 CS0<br>1: SSP0 CS1                                                                                                       |
| [3]     | RW | usb2_ip_iso_ctrl    | USB2_1P IP isolation control<br>0: not isolated<br>1: isolated                                                                                                   |
| [2]     | RW | reserved            | Reserved                                                                                                                                                         |
| [1]     | RW | sdio0_card_det_mode | Polarity of the SDIO0 card detection signal<br>0: active low<br>1: active high                                                                                   |
| [0]     | RW | sdio1_card_det_mode | Polarity of the SDIO1 card detection signal<br>0: active low<br>1: active high                                                                                   |



## CPU\_STAT

CPU\_STAT is a CPU status query register.

|        | Offset Address |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |                                                                                                                     |    |    |    |    |   |   |   |         |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |
|--------|----------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|---------------------------------------------------------------------------------------------------------------------|----|----|----|----|---|---|---|---------|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|
|        | 0x000C         |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CPU_STAT      |                                                                                                                     |    |    |    |    |   |   |   |         |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |
| Bit    | 31             | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14                                                                                                                  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6       | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |
| Name   | reserved       |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |                                                                                                                     |    |    |    |    |   |   |   | smpnamp |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0                                                                                                                   | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0       | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |
| Bits   | Access         | Name     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               | Description                                                                                                         |    |    |    |    |   |   |   |         |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |
| [31:4] | RO             | reserved |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               | Reserved                                                                                                            |    |    |    |    |   |   |   |         |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |
| [3:0]  | RO             | smpnamp  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               | A7MP core SMP or AMP indicator (bit 3–bit 0 correspond to core 3–core 0 respectively)<br>0: SMP mode<br>1: AMP mode |    |    |    |    |   |   |   |         |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |

## PERI\_USB\_RESUME\_INT\_MASK

PERI\_USB\_RESUME\_INT\_MASK is a USB wakeup interrupt mask register.

|        | Offset Address |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name            |                                                              |    |    |    |    |   |   |   |   |                           |   |   |   |   |   | Total Reset Value |                           |   |   |   |  |  |  |
|--------|----------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|--------------------------------------------------------------|----|----|----|----|---|---|---|---|---------------------------|---|---|---|---|---|-------------------|---------------------------|---|---|---|--|--|--|
|        | 0x00B4         |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PERI_USB_RESUME_INT_MASK |                                                              |    |    |    |    |   |   |   |   |                           |   |   |   |   |   | 0x0000_0000       |                           |   |   |   |  |  |  |
| Bit    | 31             | 30                        | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14                                                           | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                         | 4 | 3 | 2 | 1 | 0 |                   |                           |   |   |   |  |  |  |
| Name   | reserved       |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |                                                              |    |    |    |    |   |   |   |   | usb_phy1_suspend_int_mask |   |   |   |   |   |                   |                           |   |   |   |  |  |  |
| Reset  | 0              | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0                                                            | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0                         | 0 | 0 | 0 | 0 | 0 | 0                 | 0                         | 0 | 0 | 0 |  |  |  |
| Bits   | Access         | Name                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | Description                                                  |    |    |    |    |   |   |   |   |                           |   |   |   |   |   |                   |                           |   |   |   |  |  |  |
| [31:4] | RW             | reserved                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | Reserved                                                     |    |    |    |    |   |   |   |   |                           |   |   |   |   |   |                   |                           |   |   |   |  |  |  |
| [3]    | RW             | usb_phy1_suspend_int_mask |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | USB PHY1 wakeup interrupt mask<br>0: masked<br>1: not masked |    |    |    |    |   |   |   |   |                           |   |   |   |   |   |                   | usb_phy2_suspend_int_mask |   |   |   |  |  |  |



|     |    |                           |                                                               |
|-----|----|---------------------------|---------------------------------------------------------------|
| [2] | RW | usb_phy2_suspend_int_mask | USB PHY2 wakeup interrupt mask<br>0: masked<br>1: not masked  |
| [1] | RW | usb3_utmi_suspend_n       | USB3 UTMI wakeup interrupt mask<br>0: masked<br>1: not masked |
| [0] | RW | usb_phy0_suspend_int_mask | USB PHY0 wakeup interrupt mask<br>0: masked<br>1: not masked  |

## PERI\_USB\_RESUME\_INT\_RAWSTAT

PERI\_USB\_RESUME\_INT\_RAWSTAT is a raw USB wakeup interrupt status register.

|        | Offset Address 0x00B8 Register Name PERI_USB_RESUME_INT_RAWSTAT |                              |    |    |                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    | Total Reset Value 0x0000_000F |    |    |    |    |    |   |   |   |   |   |   |   |   |                              |                              |  |
|--------|-----------------------------------------------------------------|------------------------------|----|----|-----------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------------------|------------------------------|--|
| Bit    | 31                                                              | 30                           | 29 | 28 | 27                                                                                                                    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                            | 0                            |  |
| Name   | reserved                                                        |                              |    |    |                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   |                              |                              |  |
| Reset  | 0                                                               | 0                            | 0  | 0  | 0                                                                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1                            |                              |  |
| Bits   | Access                                                          | Name                         |    |    | Description                                                                                                           |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   |                              |                              |  |
| [31:4] | RO                                                              | reserved                     |    |    | Reserved                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   |                              |                              |  |
| [3]    | RO                                                              | usb_phy1_suspend_int_rawstat |    |    | USB PHY1 suspend interrupt raw status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated.  |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   |                              | usb_phy1_suspend_int_rawstat |  |
| [2]    | RO                                                              | usb_phy2_suspend_int_rawstat |    |    | USB PHY2 suspend interrupt raw status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated.  |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   | usb_phy2_suspend_int_rawstat |                              |  |
| [1]    | RO                                                              | usb3_suspend_int_rawstat     |    |    | USB3 UTMI suspend interrupt raw status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated. |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   | usb3_suspend_int_rawstat     |                              |  |
|        |                                                                 |                              |    |    |                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                               |    |    |    |    |    |   |   |   |   |   |   |   |   |                              | usb3_suspend_int_rawstat     |  |



|     |    |                              |                                                                                                                      |
|-----|----|------------------------------|----------------------------------------------------------------------------------------------------------------------|
| [0] | RO | usb_phy0_suspend_int_rawstat | USB PHY0 suspend interrupt raw status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated. |
|-----|----|------------------------------|----------------------------------------------------------------------------------------------------------------------|

## PERI\_USB\_RESUME\_INT\_STAT

PERI\_USB\_RESUME\_INT\_STAT is a USB wakeup interrupt status register.

|        | Offset Address                  |                           | Register Name                                                                                                     | Total Reset Value |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
|--------|---------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---------------------------|---------------------------|-----------------------|---------------------------|
| Bit    | 0x00BC PERI_USB_RESUME_INT_STAT |                           |                                                                                                                   |                   |   |   |   |   |   |   |   |   |   |   |   |   | 0x0000_0000               |                           |                       |                           |
| Name   | reserved                        |                           |                                                                                                                   |                   |   |   |   |   |   |   |   |   |   |   |   |   | usb_phy1_suspend_int_stat | usb_phy2_suspend_int_stat | usb3_suspend_int_stat | usb_phy0_suspend_int_stat |
| Reset  | 0                               | 0                         | 0                                                                                                                 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                         | 0                         | 0                     | 0                         |
| Bits   | Access                          | Name                      | Description                                                                                                       |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
| [31:4] | RO                              | reserved                  | Reserved                                                                                                          |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
| [3]    | RO                              | usb_phy1_suspend_int_stat | USB PHY1 suspend interrupt status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated.  |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
| [2]    | RO                              | usb_phy2_suspend_int_stat | USB PHY2 suspend interrupt status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated.  |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
| [1]    | RO                              | usb3_suspend_int_stat     | USB3 UTMI suspend interrupt status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated. |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |
| [0]    | RO                              | usb_phy0_suspend_int_stat | USB PHY0 suspend interrupt status<br>0: No wakeup interrupt is generated.<br>1: A wakeup interrupt is generated.  |                   |   |   |   |   |   |   |   |   |   |   |   |   |                           |                           |                       |                           |

## PERI\_INT\_A9TOMCE

PERI\_INT\_A9TOMCE is a CPU-to-MCU software interrupt register.



| Offset Address |          |    |             | Register Name    |    |    |                                                                                |    |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
|----------------|----------|----|-------------|------------------|----|----|--------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|---|---|
| 0x00C0         |          |    |             | PERI_INT_A9TOMCE |    |    |                                                                                |    |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
| Bit            | 31       | 30 | 29          | 28               | 27 | 26 | 25                                                                             | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1 | 0 |
| Name           | reserved |    |             |                  |    |    |                                                                                |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   | int_a9tomce |   |   |
| Reset          | 0        | 0  | 0           | 0                | 0  | 0  | 0                                                                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           |   |   |
| Bits           | Access   |    | Name        |                  |    |    | Description                                                                    |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
| [31:1]         | RW       |    | reserved    |                  |    |    | Reserved                                                                       |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
| [0]            | RW       |    | int_a9tomce |                  |    |    | CPU-to-MCU interrupt<br>0: clear the interrupt<br>1: send an interrupt request |    |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |

PERI INT SWI0

PERI INT SWI0 is a software interrupt 0 register.

PERI\_INT\_SWI1

PERI INT SWI1 is a software interrupt 1 register.



PERI INT SWI2

**PERI\_INT\_SWI2** is a software interrupt 2 register.

## **PERI\_INT\_SWI0\_MASK**

**PERI\_INT\_SWI0\_MASK** is a software interrupt 0 mask register.



|        | Offset Address                                                                                      | Register Name      | Total Reset Value                                                                       |
|--------|-----------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------|
|        | 0x00F0                                                                                              | PERI_INT_SWI0_MASK | 0x0000_0000                                                                             |
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 |                    |                                                                                         |
| Name   |                                                                                                     | reserved           |                                                                                         |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                    |                                                                                         |
| Bits   | Access                                                                                              | Name               | Description                                                                             |
| [31:1] | RW                                                                                                  | reserved           | Reserved                                                                                |
| [0]    | RW                                                                                                  | int_swi0_mask_a9   | Mask control for software interrupt 0 transmitted to the CPU<br>0: masked<br>1: enabled |

## PERI\_INT\_SWI1\_MASK

PERI\_INT\_SWI1\_MASK is a software interrupt 1 mask register.

|        | Offset Address                                                                                      | Register Name      | Total Reset Value                                                                       |
|--------|-----------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------|
|        | 0x00F4                                                                                              | PERI_INT_SWI1_MASK | 0x0000_0000                                                                             |
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 |                    |                                                                                         |
| Name   |                                                                                                     | reserved           |                                                                                         |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                    |                                                                                         |
| Bits   | Access                                                                                              | Name               | Description                                                                             |
| [31:1] | RW                                                                                                  | reserved           | Reserved                                                                                |
| [0]    | RW                                                                                                  | int_swi1_mask_a9   | Mask control for software interrupt 1 transmitted to the CPU<br>0: masked<br>1: enabled |



## **PERI\_INT\_SWI2\_MASK**

**PERI\_INT\_SWI2\_MASK** is a software interrupt 2 mask register.

PERI TIANLA ADAC0

PERI TIANLA ADAC0 is ADAC configuration register 0.

| Offset Address |         |         |           |           |         |    |         | Register Name                                                                                                                                                                                |           |           |             |             |               |    |          | Total Reset Value |          |    |    |    |          |    |          |   |   |   |   |   |   |   |   |   |
|----------------|---------|---------|-----------|-----------|---------|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------|-------------|-------------|---------------|----|----------|-------------------|----------|----|----|----|----------|----|----------|---|---|---|---|---|---|---|---|---|
| 0x0110         |         |         |           |           |         |    |         | PERI_TIANLA_ADAC0                                                                                                                                                                            |           |           |             |             |               |    |          | 0xF840_0606       |          |    |    |    |          |    |          |   |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30      | 29        | 28        | 27      | 26 | 25      | 24                                                                                                                                                                                           | 23        | 22        | 21          | 20          | 19            | 18 | 17       | 16                | 15       | 14 | 13 | 12 | 11       | 10 | 9        | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | pd_dacl | pd_dacr | mute_dacl | mute_dacr | pd_vref | fs | popfref | popfref                                                                                                                                                                                      | dac1_path | dac1_path | dac1_deemph | dac1_deemph | deemphasis_fs |    | reserved |                   | dacl_vol |    |    |    | reserved |    | dacr_vol |   |   |   |   |   |   |   |   |   |
| Reset          | 1       | 1       | 1         | 1         | 1       | 0  | 0       | 0                                                                                                                                                                                            | 0         | 1         | 0           | 0           | 0             | 0  | 0        | 0                 | 0        | 0  | 0  | 0  | 1        | 1  | 0        | 0 | 0 | 0 | 0 | 1 | 1 | 0 |   |   |
| Bits           |         | Access  |           | Name      |         |    |         | Description                                                                                                                                                                                  |           |           |             |             |               |    |          |                   |          |    |    |    |          |    |          |   |   |   |   |   |   |   |   |   |
| [31]           |         | RW      |           | pd_dacl   |         |    |         | Power-down control for the DAC audio-left channel<br>0: The digital and analog circuits work properly.<br>1: The digital circuit works properly, whereas the analog circuit is powered down. |           |           |             |             |               |    |          |                   |          |    |    |    |          |    |          |   |   |   |   |   |   |   |   |   |



|      |    |             |                                                                                                                                                                                               |
|------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [30] | RW | pd_daer     | Power-down control for the DAC audio-right channel<br>0: The digital and analog circuits work properly.<br>1: The digital circuit works properly, whereas the analog circuit is powered down. |
| [29] | RW | mute_dacl   | Mute control for the DAC audio-left channel<br>0: The digital and analog channels work properly.<br>1: The digital and analog audio-left channels are muted.                                  |
| [28] | RW | mute_dacr   | Mute control for the DAC audio-right channel<br>0: The digital and analog audio-right channels work properly.<br>1: The digital and analog audio-right channels are muted.                    |
| [27] | RW | pd_vref     | Power-down control for the reference voltage<br>0: powered on<br>1: powered down                                                                                                              |
| [26] | RW | fs          | Fast startup enable for the reference voltage<br>0: disabled<br>1: enabled                                                                                                                    |
| [25] | RW | popfreel    | Pop-free enable for the DAC audio-left channel<br>0: disabled<br>1: enabled                                                                                                                   |
| [24] | RW | popfreer    | Pop-free enable for the DAC audio-right channel<br>0: disabled<br>1: enabled                                                                                                                  |
| [23] | RW | dACL_path   | Data source of the DAC audio-left channel<br>0: RX data 1 from the I <sup>2</sup> S interface (audio-left channel)<br>1: RX data 2 from the I <sup>2</sup> S interface (audio-right channel)  |
| [22] | RW | dACR_path   | Data source of the DAC audio-right channel<br>0: RX data 1 from the I <sup>2</sup> S interface (audio-left channel)<br>1: RX data 2 from the I <sup>2</sup> S interface (audio-right channel) |
| [21] | RW | dACL_deemph | De-emphasis filter enable for the DAC audio-left channel<br>1: enabled<br>0: disabled                                                                                                         |
| [20] | RW | dACR_deemph | De-emphasis filter enable for the DAC audio-right channel<br>1: enabled<br>0: disabled                                                                                                        |



|         |    |               |                                                                                                                                |
|---------|----|---------------|--------------------------------------------------------------------------------------------------------------------------------|
| [19:18] | RW | deemphasis_fs | De-emphasis sampling rate<br>00: 48 kHz<br>01: 44.1 kHz<br>10: 32 kHz<br>11: reserved                                          |
| [17:15] | RW | reserved      | Reserved                                                                                                                       |
| [14:8]  | RW | dacl_vol      | Output volume of the audio-left channel<br>0x00: 6 dB<br>0x01: 5 dB<br>0x06: 0 dB<br>... (The step is 1 dB.)<br>0x7F: -121 dB  |
| [7]     | RW | reserved      | Reserved                                                                                                                       |
| [6:0]   | RW | dacr_vol      | Output volume of the audio-right channel<br>0x00: 6 dB<br>0x01: 5 dB<br>0x06: 0 dB<br>... (The step is 1 dB.)<br>0x7F: -121 dB |

## PERI\_TIANLA\_ADAC1

PERI\_TIANLA\_ADAC1 is ADAC configuration register 1.

| Offset Address |        |        |                                              |          |       |           |          | Register Name     |            |          |          |          |         |          |     | Total Reset Value |         |           |             |          |          |          |            |          |          |          |          |          |          |          |   |   |
|----------------|--------|--------|----------------------------------------------|----------|-------|-----------|----------|-------------------|------------|----------|----------|----------|---------|----------|-----|-------------------|---------|-----------|-------------|----------|----------|----------|------------|----------|----------|----------|----------|----------|----------|----------|---|---|
| 0x0114         |        |        |                                              |          |       |           |          | PERI_TIANLA_ADAC1 |            |          |          |          |         |          |     | 0x00E0_6755       |         |           |             |          |          |          |            |          |          |          |          |          |          |          |   |   |
| Bit            | 31     | 30     | 29                                           | 28       | 27    | 26        | 25       | 24                | 23         | 22       | 21       | 20       | 19      | 18       | 17  | 16                | 15      | 14        | 13          | 12       | 11       | 10       | 9          | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1 | 0 |
| Name           | smutel | smuter | summute1                                     | summute2 | dacv1 | mute_rate | reserved | data_bits         | sample_sel | reserved | reserved | reserved | adj_dac | adj_ctem | rst | adj_refbf         | clkse12 | clkdgesel | reserved    | reserved | reserved | reserved | reserved   | reserved | reserved | reserved | reserved | reserved | reserved | reserved |   |   |
| Reset          | 0      | 0      | 0                                            | 0        | 0     | 0         | 0        | 0                 | 1          | 1        | 1        | 0        | 0       | 0        | 0   | 0                 | 1       | 1         | 0           | 0        | 1        | 1        | 1          | 0        | 0        | 1        | 0        | 1        | 0        | 1        |   |   |
| Bits           |        | Access |                                              | Name     |       |           |          | Description       |            |          |          |          |         |          |     |                   |         |           |             |          |          |          |            |          |          |          |          |          |          |          |   |   |
| [31]           | RW     | smutel | Soft mute control for the audio-left channel |          |       |           |          |                   |            |          |          |          |         |          |     |                   |         |           | 0: disabled |          |          |          | 1: enabled |          |          |          |          |          |          |          |   |   |



|         |    |            |                                                                                                                                                                                                                                                                      |
|---------|----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [30]    | RW | smuter     | Soft mute control for the audio-right channel<br>0: disabled<br>1: enabled                                                                                                                                                                                           |
| [29]    | RW | sunmutel   | Soft unmute control for the audio-left channel of the digital circuit<br>0: disabled<br>1: enabled                                                                                                                                                                   |
| [28]    | RW | sunmuter   | Soft unmute control for the audio-right channel of the digital circuit<br>0: disabled<br>1: enabled                                                                                                                                                                  |
| [27]    | RW | dacvu      | Volume sync update of the digital audio-right and audio-left channels<br>0: The gains of the audio-left and audio-right channels remain unchanged.<br>1: The volumes of audio-left and audio-right channels are simultaneously updated.                              |
| [26:25] | RW | mute_rate  | Volume gain step when the audio-right and audio-left channels are soft muted or soft unmuted<br>00: fs/2<br>01: fs/8<br>10: fs/32<br>11: fs/64                                                                                                                       |
| [24]    | RW | reserved   | Reserved                                                                                                                                                                                                                                                             |
| [23:22] | RW | data_bits  | Interface data bit width<br>00: 16 bits<br>01: 18 bits<br>10: 20 bits<br>11: 24 bits                                                                                                                                                                                 |
| [21:19] | RW | sample_sel | Sampling rate<br>000: 1/4 of the reference sampling rate<br>001: 1/2 of the reference sampling rate<br>010: reference sampling rate<br>011: 2 times the reference sampling rate<br>100: 4 times the reference sampling rate<br>Other values: reference sampling rate |
| [18:16] | RW | reserved   | Reserved                                                                                                                                                                                                                                                             |



|         |    |           |                                                                                                                                                                            |
|---------|----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:14] | RW | adj_dac   | DAC bias current<br>00: 0.6 times the current<br>01: normal current (recommended)<br>10: 1.4 times the current<br>11: 2 times the current                                  |
| [13]    | RW | adj_ctcm  | CTCM bias current<br>0: normal current (recommended)<br>1: 2 times the current                                                                                             |
| [12]    | RW | rst       | STB_DAC_ANA reset<br>0: normal mode<br>1: reset                                                                                                                            |
| [11:10] | RW | adj_refbf | Reference buffer bias current<br>00: 0.6 times the current<br>01: normal current (recommended)<br>10: 1.4 times the current<br>11: 2 times the current                     |
| [9]     | RW | clksel2   | 2-divider clock select<br>0: divide-by-2 clock<br>1: input clock                                                                                                           |
| [8]     | RW | clkdgesel | Clock edge select<br>0: The rising edge is selected as the sampling clock of the analog part.<br>1: The falling edge is selected as the sampling clock of the analog part. |
| [7:0]   | RW | reserved  | Reserved                                                                                                                                                                   |



## PERI\_FEPHY

PERI\_FEPHY is an FE PHY configuration register.

| Offset Address |                 |                     |    |                                                           |    |    |    |    |    | Register Name |          |                   |          |                     |          |                    |          | Total Reset Value |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-----------------|---------------------|----|-----------------------------------------------------------|----|----|----|----|----|---------------|----------|-------------------|----------|---------------------|----------|--------------------|----------|-------------------|----------|----------|----------------|----|---|---|---|---|---|---|---|---|---|---|
| 0x0118         |                 |                     |    |                                                           |    |    |    |    |    | PERI_FEPHY    |          |                   |          |                     |          |                    |          | 0x0300_0001       |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31              | 30                  | 29 | 28                                                        | 27 | 26 | 25 | 24 | 23 | 22            | 21       | 20                | 19       | 18                  | 17       | 16                 | 15       | 14                | 13       | 12       | 11             | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | soft_fephy_gp_i |                     |    |                                                           |    |    |    |    |    |               | reserved | soft_fephy_mdio_i | reserved | soft_fephy_mdio_mdc | reserved | fephy_patch_enable | reserved | fephy_tclk_enable | reserved | reserved | fephy_phy_addr |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0               | 0                   | 0  | 0                                                         | 0  | 0  | 1  | 1  | 0  | 0             | 0        | 0                 | 0        | 0                   | 0        | 0                  | 0        | 0                 | 0        | 0        | 0              | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 |   |   |   |
| Bits           | Access          | Name                |    | Description                                               |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW              | soft_fephy_gp_i     |    | GP data input when the FE PHY downloads patches           |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [15]           | RW              | reserved            |    | Reserved                                                  |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [14]           | RW              | soft_fephy_mdio_i   |    | MDIO data input when the FE PHY downloads patches         |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [13]           | RW              | reserved            |    | Reserved                                                  |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [12]           | RW              | soft_fephy_mdio_mdc |    | MDC data input when the FE PHY downloads patches          |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [11]           | RW              | reserved            |    | Reserved                                                  |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [10]           | RW              | fephy_patch_enable  |    | FE PHY download patch enable<br>0: disabled<br>1: enabled |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [9]            | RW              | reserved            |    | Reserved                                                  |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [8]            | RW              | fephy_tclk_enable   |    | FE PHY debugging enable.<br>0: disabled<br>1: enabled     |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [7:5]          | RW              | reserved            |    | Reserved                                                  |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |
| [4:0]          | RW              | fephy_phy_addr      |    | FE PHY address                                            |    |    |    |    |    |               |          |                   |          |                     |          |                    |          |                   |          |          |                |    |   |   |   |   |   |   |   |   |   |   |



PERI\_SD\_LDO

**PERI\_SD\_LDO** is an SDIO0 LDO control register.

| Offset Address |          |          |    |                                                                                     |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-------------------------------------------------------------------------------------|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|--------|----|------|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x011C         |          |          |    |                                                                                     |    |    |    | PERI_SD_LDO   |    |    |    |    |    |    |    | 0x0000_0060       |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                                  | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15     | 14 | 13   | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |                                                                                     |    |    |    |               |    |    |    |    |    |    |    |                   | bypass | en | vset | fuse |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                                   | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0      | 0  | 0    | 0    | 0  | 0  | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    | Description                                                                         |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:7]         | RO       | reserved |    | Reserved                                                                            |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| [6]            | RW       | bypass   |    | LDO bypass enable<br>0: disabled<br>1: enabled (the VIN voltage is directly output) |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| [5]            | RW       | en       |    | LDO enable<br>0: disabled<br>1: enabled                                             |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| [4]            | RW       | vset     |    | LDO output voltage<br>0: 1.8 V<br>1: 1.2 V                                          |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |
| [3:0]          | RW       | fuse     |    | Reference voltage for accurately adjusting the internal voltage                     |    |    |    |               |    |    |    |    |    |    |    |                   |        |    |      |      |    |    |   |   |   |   |   |   |   |   |   |   |



## PERI\_USB0

PERI\_USB0 is USB 2.0 controller configuration register 0.

| Bit     | Offset Address<br>0x0120 |                    |        |                                                                                                                                                                                                                                                                                                                                                         |    |    |    |                   |          |    |    |    |    |    |    |    | Register Name<br>PERI_USB0 |    |    |    |                 |                |                |                     | Total Reset Value<br>0x000C_71A8 |          |                 |                 |                  |              |   |   |  |  |
|---------|--------------------------|--------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-------------------|----------|----|----|----|----|----|----|----|----------------------------|----|----|----|-----------------|----------------|----------------|---------------------|----------------------------------|----------|-----------------|-----------------|------------------|--------------|---|---|--|--|
|         | 31                       | 30                 | 29     | 28                                                                                                                                                                                                                                                                                                                                                      | 27 | 26 | 25 | 24                | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                         | 14 | 13 | 12 | 11              | 10             | 9              | 8                   | 7                                | 6        | 5               | 4               | 3                | 2            | 1 | 0 |  |  |
| Name    | ohci_0_cntsel_i_n        | ss_scaledown_mode  | chipid | reserved                                                                                                                                                                                                                                                                                                                                                |    |    |    | ss_hubsetup_min_i | reserved |    |    |    |    |    |    |    |                            |    |    |    | ss_ena_incr16_i | ss_ena_incr8_i | ss_ena_incr4_i | ss_ena_incr_align_i | ss_autopd_on_overcur_en_i        | reserved | ulp_bypass_en_i | app_start_clk_i | ohci_susp_lgey_i | ss_word_if_i |   |   |  |  |
| Reset   | 0                        | 0                  | 0      | 0                                                                                                                                                                                                                                                                                                                                                       | 0  | 0  | 0  | 0                 | 0        | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0                          | 1  | 1  | 1  | 0               | 0              | 0              | 1                   | 1                                | 0        | 1               | 0               | 0                | 0            | 0 |   |  |  |
| Bits    | Access                   | Name               |        | Description                                                                                                                                                                                                                                                                                                                                             |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [31]    | RW                       | ohci_0_cntsel_i_n  |        | Interval for transmitting USB SOF packets<br>0: SOF packets are transmitted every 1 ms (normal interval).<br>1: The interval is reduced for simulation.                                                                                                                                                                                                 |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [30:29] | RW                       | ss_scaledown_mod_e |        | Scale-down mode<br>00: Scale-down is disabled for all timings, and the actual timings are used.<br>01: Scale-down is enabled for all timings except the suspended and resumed timings in device mode.<br>10: Scale-down is enabled only for the suspended and resumed timings in device mode.<br>11: Scale-down timings of bit 0 and bit 1 are enabled. |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [28]    | RW                       | chipid             |        | USB PHY controller select<br>0: USB host port 0<br>1: reserved                                                                                                                                                                                                                                                                                          |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [27:23] | RW                       | reserved           |        | Reserved                                                                                                                                                                                                                                                                                                                                                |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [22]    | RW                       | ss_hubsetup_min_i  |        | Number of idle cycles after the full-speed preamble packet<br>0: 5 full-speed idle cycles<br>1: 4 full-speed idle cycles                                                                                                                                                                                                                                |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [21:10] | RW                       | reserved           |        | Reserved                                                                                                                                                                                                                                                                                                                                                |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |
| [9]     | RW                       | ss_ena_incr16_i    |        | AHB burst 16 enable<br>0: disabled<br>1: enabled (default)                                                                                                                                                                                                                                                                                              |    |    |    |                   |          |    |    |    |    |    |    |    |                            |    |    |    |                 |                |                |                     |                                  |          |                 |                 |                  |              |   |   |  |  |



|     |    |                            |                                                                                                                                                       |
|-----|----|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8] | RW | ss_ena_incr8_i             | AHB burst 8 enable<br>0: disabled<br>1: enabled (default)                                                                                             |
| [7] | RW | ss_ena_incr4_i             | AHB burst 4 enable<br>0: disabled<br>1: enabled (default)                                                                                             |
| [6] | RW | ss_ena_incr_align_i        | Burst alignment enable<br>0: disabled (default)<br>1: enabled                                                                                         |
| [5] | RW | ss_autoppd_on_overcur_en_i | Automatic port power shutdown enable during overcurrent<br>0: disabled<br>1: enabled (default)                                                        |
| [4] | -  | reserved                   | Reserved                                                                                                                                              |
| [3] | RW | ulpi_bypass_en_i           | UTMI+ low pin interface (ULPI) bypass control. This bit must be set to 1.<br>0: ULPI mode<br>1: UTMI mode                                             |
| [2] | RW | app_start_clk_i            | Open host controller interface (OHCI) clock control signal.<br>0: The OHCI works properly. (default)<br>1: The OHCI clock is enabled in suspend mode. |
| [1] | RW | ohci_susp_lgcy_i           | Strap input signal when the OHCI is suspended                                                                                                         |
| [0] | RW | ss_word_if_i               | Data bit width select signal of the UTMI interface<br>0: 8 bits (default)<br>1: 16 bits                                                               |



## PERI\_USB1

PERI\_USB1 is a USB 2.0 PHY configuration register.

|         | Offset Address |             |    |                                                   |    |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
|---------|----------------|-------------|----|---------------------------------------------------|----|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|----------|-----------|-----------|----|----|---|---|---|---|---|-------------|---|---|---|---|
|         | 0x0124         |             |    |                                                   |    |    |    |    | PERI_USB1     |    |    |    |    |    |    |    | 0x0000_0000       |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| Bit     | 31             | 30          | 29 | 28                                                | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                | 14       | 13        | 12        | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4           | 3 | 2 | 1 | 0 |
| Name    | reserved       |             |    |                                                   |    |    |    |    | test_rddata   |    |    |    |    |    |    |    | test_rstn         | test_clk | test_wren | test_addr |    |    |   |   |   |   |   | test_wrdata |   |   |   |   |
| Reset   | 0              | 0           | 0  | 0                                                 | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0        | 0         | 0         | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0           | 0 | 0 | 0 |   |
| Bits    | Access         | Name        |    | Description                                       |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [31:24] | RO             | reserved    |    | Reserved                                          |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [23:16] | RO             | test_rddata |    | Data read signal of the debugging channel         |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [15]    | RW             | test_rstn   |    | Reset signal of the debugging channel             |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [14]    | RW             | test_clk    |    | Clock signal of the debugging channel             |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [13]    | RW             | test_wren   |    | Read/Write enable signal of the debugging channel |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [12:8]  | RW             | test_addr   |    | Address signal of the debugging channel           |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |
| [7:0]   | RW             | test_wrdata |    | Data write signal of the debugging channel        |    |    |    |    |               |    |    |    |    |    |    |    |                   |          |           |           |    |    |   |   |   |   |   |             |   |   |   |   |

## PERI\_USB5

PERI\_USB5 is USB 3.0 control register 0.

|       | Offset Address    |    |    |    |    |    |    |    | Register Name     |    |    |    |          |    |                 |    | Total Reset Value |    |    |    |    |    |                 |   |                                 |   |                     |   |                     |   |                      |   |          |  |
|-------|-------------------|----|----|----|----|----|----|----|-------------------|----|----|----|----------|----|-----------------|----|-------------------|----|----|----|----|----|-----------------|---|---------------------------------|---|---------------------|---|---------------------|---|----------------------|---|----------|--|
|       | 0x0134            |    |    |    |    |    |    |    | PERI_USB5         |    |    |    |          |    |                 |    | 0x7E8F_2040       |    |    |    |    |    |                 |   |                                 |   |                     |   |                     |   |                      |   |          |  |
| Bit   | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                | 22 | 21 | 20 | 19       | 18 | 17              | 16 | 15                | 14 | 13 | 12 | 11 | 10 | 9               | 8 | 7                               | 6 | 5                   | 4 | 3                   | 2 | 1                    | 0 |          |  |
| Name  | host_current_belt |    |    |    |    |    |    |    | bus_filter_bypass |    |    |    | reserved |    | fladj_30mhz_reg |    |                   |    |    |    |    |    | host_msi_enable |   | host_port_power_control_present |   | hub_u3_port_disable |   | hub_u2_port_disable |   | hub_port_perm_attach |   | reserved |  |
| Reset | 0                 | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 1                 | 0  | 0  | 0  | 1        | 1  | 1               | 1  | 0                 | 0  | 0  | 1  | 0  | 0  | 0               | 0 | 0                               | 1 | 0                   | 0 | 0                   | 0 | 0                    | 0 |          |  |



| Bits    | Access | Name                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|--------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | RO     | host_current_belt                   | Current BELT value                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [19:16] | RW     | bus_filter_bypass                   | UTMI bus signal filter enable<br>bus_filter_bypass[3]<br>The function of filtering out the utmiotg_iddig signal is disabled.<br>bus_filter_bypass[2]<br>The function of filtering out the utmisrp_bvalid and<br>utmisrp_sessend signals is disabled.<br>bus_filter_bypass[1]<br>The function of filtering out the pipe3_PowerPresent signal of port<br>U3 is disabled.<br>bus_filter_bypass[0]<br>The function of filtering out the utmiotg_vbusvalid signal of port<br>U2 is disabled. |
| [15:14] | RW     | reserved                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [13:8]  | RW     | fladj_30mhz_reg                     | High-speed signal jitter adjustment<br>mac3_clock and utmi_clock are adjusted to 125 μs.                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]     | RW     | host_msi_enable                     | Pulse interrupt enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [6]     | RW     | host_port_power_c<br>ontrol_present | Port power switch enable<br>1'b0: The port has no power switch.<br>1'b1: The port has a power switch.                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]     | RW     | hub_u3_port_disabl<br>e             | USB 3.0 super-speed port enable<br>1'b0: enabled<br>1'b1: disabled                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [4]     | RW     | hub_u2_port_disabl<br>e             | USB 3.0 high-speed port enable<br>1'b0: The port is enabled.<br>1'b1: The port is disabled.                                                                                                                                                                                                                                                                                                                                                                                             |
| [3:2]   | RW     | hub_port_perm_att<br>ach            | Device permanent insertion<br>1'b0: The device is inserted permanently.<br>1'b1: The device is not inserted permanently.                                                                                                                                                                                                                                                                                                                                                                |
| [1:0]   | RW     | reserved                            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



## PERI\_USB6

PERI\_USB6 is USB 3.0 PCS control register 1.

|         | Offset Address |                             |    |                                                                                                                                                                                      |    |    |    |    | Register Name |                   |                     |    |    |    |    |    | Total Reset Value |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
|---------|----------------|-----------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|---------------|-------------------|---------------------|----|----|----|----|----|-------------------|----|-------------------|-----------------------------|--------------------------|--------------------|----------|--------------|---|---|---|---|---|---|---|---|
|         | 0x0138         |                             |    |                                                                                                                                                                                      |    |    |    |    | PERI_USB6     |                   |                     |    |    |    |    |    | 0x5D81_560D       |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| Bit     | 31             | 30                          | 29 | 28                                                                                                                                                                                   | 27 | 26 | 25 | 24 | 23            | 22                | 21                  | 20 | 19 | 18 | 17 | 16 | 15                | 14 | 13                | 12                          | 11                       | 10                 | 9        | 8            | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved       | pcs_tx_swing_full           |    |                                                                                                                                                                                      |    |    |    |    |               | pcs_tx_deemph_6db | pcs_tx_deemph_3p5db |    |    |    |    |    |                   |    | lane0_tx2rx_lopbk | lane0_power_present_ovrd_en | lane0_power_present_ovrd | lane0_ext_pclk_req | reserved | usb_pwr_ctrl |   |   |   |   |   |   |   |   |
| Reset   | 0              | 1                           | 0  | 1                                                                                                                                                                                    | 1  | 1  | 0  | 1  | 1             | 0                 | 0                   | 0  | 0  | 0  | 0  | 1  | 0                 | 1  | 0                 | 1                           | 0                        | 1                  | 1        | 0            | 0 | 0 | 0 | 1 | 1 | 0 | 1 |   |
| Bits    | Access         |                             |    |                                                                                                                                                                                      |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [31]    | RW             | reserved                    |    | Reserved                                                                                                                                                                             |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [30:24] | RW             | pcs_tx_swing_full           |    | TX signal swing (for the eye pattern test)                                                                                                                                           |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [23:18] | RW             | pcs_tx_deemph_6db           |    | Preemphasis of 6 dB reduction (for the eye pattern test)                                                                                                                             |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [17:12] | RW             | pcs_tx_deemph_3p5db         |    | Preemphasis of 3.5 dB reduction (for the eye pattern test)                                                                                                                           |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [11]    | RW             | lane0_tx2rx_lopbk           |    | Lane 0 TX-to-RX loopback enable                                                                                                                                                      |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [10]    | RW             | lane0_power_present_ovrd_en |    | Lane 0 overcurrent protection enable                                                                                                                                                 |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [9]     | RW             | lane0_power_present_ovrd    |    | Lane 0 overcurrent protection                                                                                                                                                        |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [8]     | RW             | lane0_ext_pclk_req          |    | Lane 0 external pipe clock enable                                                                                                                                                    |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [7:4]   | RW             | reserved                    |    | Reserved                                                                                                                                                                             |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |
| [3:0]   | RW             | usb_pwr_ctrl                |    | Power control<br>usb_pwr_ctrl[0]: power switch<br>usb_pwr_ctrl[1]: overcurrent protection enable<br>usb_pwr_ctrl[2]: power switch polarity<br>usb_pwr_ctrl[3]: power switch polarity |    |    |    |    |               |                   |                     |    |    |    |    |    |                   |    |                   |                             |                          |                    |          |              |   |   |   |   |   |   |   |   |

## PERI\_USB7

PERI\_USB7 is USB 3.0 PHY system controller 0.



| Offset Address |                                                                     |           |  |  |  |  |  |  |  |  |  |  |  |  |  | Register Name |                     |  |  |  |  |  |             | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|---------------------------------------------------------------------|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|---------------|---------------------|--|--|--|--|--|-------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x013C                                                              |           |  |  |  |  |  |  |  |  |  |  |  |  |  | PERI_USB7     |                     |  |  |  |  |  | 0x0000_0000 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | crdatain                                                            |           |  |  |  |  |  |  |  |  |  |  |  |  |  | crdataout     |                     |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |           |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                     |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                              | Name      |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Description         |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:16]        | RO                                                                  | crdatain  |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Current input data  |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [15:0]         | RW                                                                  | crdataout |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Current output data |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |

## PERI\_USB8

PERI\_USB8 is USB 3.0 PHY system controller 1.

| Offset Address |         |                |                |                |         |           |         |         |         |             |         |         |                 |         |                 | Register Name   |                                                                                                                         |                 |                 |                 |                 |                 |                 | Total Reset Value |                 |                 |                 |                 |  |  |  |
|----------------|---------|----------------|----------------|----------------|---------|-----------|---------|---------|---------|-------------|---------|---------|-----------------|---------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------------|-----------------|-----------------|-----------------|-----------------|--|--|--|
| Bit            | 0x0140  |                |                |                |         |           |         |         |         |             |         |         |                 |         |                 | PERI_USB8       |                                                                                                                         |                 |                 |                 |                 |                 | 0x9689_A100     |                   |                 |                 |                 |                 |  |  |  |
| Name           | otgtune | otgdisable0    | mpllrefssclken | mpllmultiplier |         |           |         |         |         |             |         |         |                 |         |                 | loslevel        | losbias                                                                                                                 | loopbackenb0    | idpullup0       | iddig0          | drvibus0        | compdistune0    | commonon0       | crack             | crwrite         | erread          | creaddata       | crecapaddr      |  |  |  |
| Reset          | 1 0 0 1 | 0 1 1 0        | 1 0 0 0 0      | 1 0 0 1        | 1 0 1 0 | 1 0 0 0 0 | 1 0 0 1 | 1 0 1 0 | 1 0 0 1 | 0 0 0 0 0 0 | 1 0 0 1 | 1 0 0 1 | 0 0 0 0 0 0 0 0 | 1 0 0 1 | 0 0 0 0 0 0 0 0 | 1 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0                                                                                                         | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0   | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 | 0 0 0 0 0 0 0 0 |  |  |  |
| Bits           | Access  | Name           |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Description                                                                                                             |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [31:29]        | RW      | otgtune        |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Vbus valid threshold adjust<br>1 bit = 1.5%                                                                             |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [28]           | RW      | otgdisable0    |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | PHY OTG disable                                                                                                         |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [27]           | RW      | mpllrefssclken |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Spread reference clock output. It is 20 MHz and provides the clock for the hardcore of the clock source of ref_alt_clk. |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [26:20]        | RW      | mpllmultiplier |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | MPLL frequency multiplier control for obtaining a specified working frequency                                           |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [19:16]        | RW      | loslevel       |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Sensitivity level detection for the loss-of-signal (LOS) detector                                                       |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [15:13]        | RW      | losbias        |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Level threshold detection for the LOS detector                                                                          |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [12]           | RW      | loopbackenb0   |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Loopback enable                                                                                                         |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |
| [11]           | RW      | idpullup0      |                |                |         |           |         |         |         |             |         |         |                 |         |                 |                 | Sampling enable for the analog ID input signal                                                                          |                 |                 |                 |                 |                 |                 |                   |                 |                 |                 |                 |  |  |  |



|       |    |              |                                                                                                                                                                       |
|-------|----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10]  | RO | iddig0       | Mini-A or mini-B connector connected to the PHY<br>1: mini-B connector<br>0: mini-A connector                                                                         |
| [9]   | RW | drvbus0      | Vbus valid comparator enable<br>1: enabled<br>0: disabled                                                                                                             |
| [8:6] | RW | compdistune0 | Disconnection event detection voltage threshold. This field is used to set the voltage threshold for the disconnection event between the device and the host.         |
| [5]   | RW | commomon0    | Common module enable<br>1: The HS bias and PLL modules are disabled in suspend or sleep mode.<br>0: The HS bias and PLL modules are enabled in suspend or sleep mode. |
| [4]   | RO | crack        | Controller signal (as the response to the CRWRITE, CRREAD, CRCAPDATA, and CRCAPSDDR signals)                                                                          |
| [3]   | RW | crwrite      | Register write control signal                                                                                                                                         |
| [2]   | RW | crread       | Register read control signal                                                                                                                                          |
| [1]   | RW | crcapdata    | Register data capture control signal. cr_data_in[15:0] are transferred to the written data.                                                                           |
| [0]   | RW | crcapaddr    | Register address capture control signal. cr_data_in[15:0] are transferred to the address register.                                                                    |



## PERI\_USB9

PERI\_USB9 is USB 3.0 PHY system controller 2.

| Offset Address |                |                   |              |                                                                                                                                                                                                     |          |             |               |         |       |           |           | Register Name |    |    |    |    |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |  |  |  |
|----------------|----------------|-------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-------------|---------------|---------|-------|-----------|-----------|---------------|----|----|----|----|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|--|--|--|
| 0x0144         |                |                   |              |                                                                                                                                                                                                     |          |             |               |         |       |           |           | PERI_USB9     |    |    |    |    |    |    |    |    |    |    |   | 0x0684_6017       |   |   |   |   |   |   |   |   |  |  |  |
| Bit            | 31             | 30                | 29           | 28                                                                                                                                                                                                  | 27       | 26          | 25            | 24      | 23    | 22        | 21        | 20            | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | txpreemppulse0 | txpreempamp tune0 | txfuslstune0 | sscrefclk sel                                                                                                                                                                                       | reserved | txhsxvtune0 | tx0termoffset | ssrange | sscen | sqrxtune0 | retenable |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| Reset          | 0              | 0                 | 0            | 0                                                                                                                                                                                                   | 0        | 1           | 1             | 0       | 1     | 0         | 0         | 0             | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0 | 0                 | 0 | 1 | 0 | 1 | 1 | 1 |   |   |  |  |  |
| Bits           | Access         | Name              |              | Description                                                                                                                                                                                         |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [31]           | RW             | txpreemppulse0    |              | TX end preemphasis time in high-speed mode<br>1: 580 $\mu$ s<br>0: 2x580 $\mu$ s                                                                                                                    |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [30:29]        | RW             | txpreempamp tune0 |              | TX end preemphasis tune in high-speed mode<br>11: 1800 $\mu$ A<br>10: 1200 $\mu$ A<br>01: 600 $\mu$ A<br>00: Preemphasis is disabled                                                                |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [28:25]        | RW             | txfuslstune0      |              | Source impedance tune in full-speed or low-speed mode<br>Hot codes are used. The impedance is reduced by 2.5% each time a hot code is added, and increased by 2.5% each time a hot code is reduced. |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [24:16]        | RW             | sscrefclk sel     |              | Spread spectrum reference clock select                                                                                                                                                              |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [15]           | RW             | reserved          |              | Reserved                                                                                                                                                                                            |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [14:13]        | RW             | txhsxvtune0       |              | TX end DP/DM voltage tune in high-speed mode<br>11: default configuration<br>10: +15 mV<br>01: -15 mV<br>00: reserved                                                                               |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [12:8]         | RW             | tx0termoffset     |              | TX termination compensation tune enable                                                                                                                                                             |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [7:5]          | RW             | ssrange           |              | Spread spectrum clock range                                                                                                                                                                         |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |
| [4]            | RW             | sscen             |              | Spread spectrum enable                                                                                                                                                                              |          |             |               |         |       |           |           |               |    |    |    |    |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |  |  |



|       |    |            |                                                                                                                                                                              |
|-------|----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:1] | RW | sqrxtune0  | High-speed data detection level tune<br>The level is decreased by 5% each time a binary value is added, and increased by 5% each time a binary value is reduced.             |
| [0]   | RW | retenablen | Low digital power indicator, indicating that the VP digital power is decreased in suspend mode<br>1: The normal operating mode is used.<br>0: The analog power is shut down. |

## PERI\_USB10

PERI\_USB10 is USB 3.0 PHY system controller 3.

|         | Offset Address 0x0148 |                  |                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name PERI_USB10 |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   | Total Reset Value 0x0006_7005 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------|-----------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|------------|-------------|------------|------------------|------------------|--------|---------|-------------|-------------|-------------|------------|---|---|---|---|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit     | 31                    | 30               | 29                                                                                                                                                                                   | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14         | 13          | 12         | 11               | 10               | 9      | 8       | 7           | 6           | 5           | 4          | 3 | 2 | 1 | 0 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name    | reserved              |                  |                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    | vbusvldexsel0            | vbusvldex0 | txvrectune0 | txboostlvl | testpowerdownssp | testpowerdownhsp | rtunek | rtunreq | vdaisrcenb0 | vdatdetenb0 | txrisetune0 | txrestune0 |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset   | 0                     | 0                | 0                                                                                                                                                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0                        | 1          | 1           | 1          | 0                | 0                | 0      | 0       | 0           | 0           | 0           | 0          | 0 | 1 | 0 | 1 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits    | Access                | Name             | Description                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:19] | RW                    | reserved         | Reserved                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [18]    | RW                    | vbusvldexsel0    | External Vbus valid indicator signal<br>1: VBUSVLDEXT0<br>0: internal comparator                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [17]    | RW                    | vbusvldex0       | External Vbus valid indicator signal<br>1: The Vbus0 signal and the pull-up resistor on D+ are valid.<br>0: The Vbus0 signal is invalid, and the pull-up resistor on D+ is disabled. |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [16:13] | RW                    | txvrectune0      | DC voltage tune in high-speed mode<br>The voltage is increased by 1.25% each time the binary value 1 is added, and decreased by 1.25% each time the binary value 1 is reduced.       |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [12:10] | RW                    | txboostlvl       | TX voltage increase                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [9]     | RW                    | testpowerdownssp | Power-off control for the super-speed functional circuit                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [8]     | RW                    | testpowerdownhsp | Power-off control for the high-speed functional circuit                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |            |             |            |                  |                  |        |         |             |             |             |            |   |   |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



|       |    |             |                                                                                                                                                                                                                        |
|-------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | RO | rtunreq     | Impedance tune acknowledge enable                                                                                                                                                                                      |
| [6]   | RW | rtunreq     | Impedance tune request                                                                                                                                                                                                 |
| [5]   | RW | vdatsrcenb0 | Charging power select<br>1: The data source voltage (VDAT_SRC) is enabled.<br>0: The data source voltage (VDAT_SRC) is disabled.                                                                                       |
| [4]   | RW | vdatdetenb0 | Charging connection/disconnection detection enable<br>1: The data detection voltage is enabled.<br>0: The data detection voltage is disabled.                                                                          |
| [3:2] | RW | txrisetune0 | Rising/Falling edge time tune for the TX end in high-speed mode<br>The rising/falling edge time is decreased by 4% each time the binary value 1 is added, and increased by 4% each time the binary value 1 is reduced. |
| [1:0] | RW | txrestune0  | USB matched source impedance tune                                                                                                                                                                                      |

## PERI\_USB12

PERI\_USB12 is USB 3.0 system controller 2.

|         | Offset Address |                     |    |    |                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |                     |   |   |   |   |   |   | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------|----------------|---------------------|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---------------------|---|---|---|---|---|---|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|         | 0x0150         |                     |    |    |                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    | PERI_USB12    |    |    |    |    |    |   |   |   |                     |   |   |   |   |   |   | 0x0000_00F0       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit     | 31             | 30                  | 29 | 28 | 27                                                                                                                                                                                                                                      | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name    | reserved       |                     |    |    |                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   | pcs_rx_los_mask_val |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset   | 0              | 0                   | 0  | 0  | 0                                                                                                                                                                                                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 1                   | 1 | 1 | 0 | 0 | 0 | 0 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits    | Access         | Name                |    |    | Description                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |                     |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:10] | RW             | reserved            |    |    | Reserved                                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |                     |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [9:0]   | RW             | pcs_rx_los_mask_val |    |    | Number of reference clock cycles to mask the incoming LFPS<br>For normal operations, set this bit to 10 µs/Tref_clk (a targeted<br>mask interval of 10 µs). If the ref_clkdiv2 signal is used, set this<br>bit to 10 µs/(2 x Tref_clk). |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |                     |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



## PERI\_USB13

PERI\_USB13 is USB controller configuration register 1.

|         | Offset Address                                                                                      | Register Name                                                                                                                                                                                 | Total Reset Value                                                                                                                                       |
|---------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | PERI_USB13                                                                                                                                                                                    | 0x000C_71A8                                                                                                                                             |
| Name    | ohci_0_cntsel_i_n<br><br>reserved<br><br>ss_hubsetup_min_i<br><br>reserved                          | ss_ena_incr16_i<br>ss_ena_incr8_i<br>ss_ena_incr4_i<br>ss_ena_incr_align_i<br>ss_autopd_on_overcur_en_i<br>reserved<br>ulp_bypass_en_i<br>app_start_clk_i<br>ohci_susp_lgey_i<br>ss_word_if_i |                                                                                                                                                         |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   1 1 0 0   0 1 1 1   0 0 0 1   1 0 1 0   1 0 0 0                       |                                                                                                                                                                                               |                                                                                                                                                         |
| Bits    | Access                                                                                              | Name                                                                                                                                                                                          | Description                                                                                                                                             |
| [31]    | RW                                                                                                  | ohci_0_cntsel_i_n                                                                                                                                                                             | Interval for transmitting USB SOF packets<br>0: SOF packets are transmitted every 1 ms (normal interval).<br>1: The interval is reduced for simulation. |
| [30:23] | RW                                                                                                  | reserved                                                                                                                                                                                      | Reserved                                                                                                                                                |
| [22]    | RW                                                                                                  | ss_hubsetup_min_i                                                                                                                                                                             | Number of idle cycles after the full-speed preamble packet<br>0: 5 full-speed idle cycles<br>1: 4 full-speed idle cycles                                |
| [21:10] | RW                                                                                                  | reserved                                                                                                                                                                                      | Reserved                                                                                                                                                |
| [9]     | RW                                                                                                  | ss_ena_incr16_i                                                                                                                                                                               | AHB burst 16 enable<br>0: disabled<br>1: enabled (default)                                                                                              |
| [8]     | RW                                                                                                  | ss_ena_incr8_i                                                                                                                                                                                | AHB burst 8 enable<br>0: disabled<br>1: enabled (default)                                                                                               |
| [7]     | RW                                                                                                  | ss_ena_incr4_i                                                                                                                                                                                | AHB burst 4 enable<br>0: disabled<br>1: enabled (default)                                                                                               |
| [6]     | RW                                                                                                  | ss_ena_incr_align_i                                                                                                                                                                           | Burst alignment enable<br>0: disabled (default)<br>1: enabled                                                                                           |



|     |    |                            |                                                                                                                     |
|-----|----|----------------------------|---------------------------------------------------------------------------------------------------------------------|
| [5] | RW | ss_autoppd_on_overcur_en_i | Automatic port power shutdown enable during overcurrent<br>0: disabled<br>1: enabled (default)                      |
| [4] | RW | reserved                   | Reserved                                                                                                            |
| [3] | RW | ulpqi_bypass_en_i          | ULPI bypass control. This bit must be set to 1.<br>0: ULPI mode<br>1: UTMI mode                                     |
| [2] | RW | app_start_clk_i            | OHCI clock control signal<br>0: The OHCI works properly. (default)<br>1: The OHCI clock is enabled in suspend mode. |
| [1] | RW | ohci_susp_lgcy_i           | Strap input signal when the OHCI is suspended. The default value is 0.                                              |
| [0] | RW | ss_word_if_i               | Data bit width select signal of the UTMI interface<br>0: 8 bits (default)<br>1: 16 bits                             |

## PERI\_USB14

PERI\_USB14 is USB PHY configuration register 1.

|         | Offset Address<br>0x0158 |             |    |    |    |                                                   |    |    |             |    |    |    |    |    |    |    | Register Name<br>PERI_USB14 |          |           |           |    |    |   |             | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |
|---------|--------------------------|-------------|----|----|----|---------------------------------------------------|----|----|-------------|----|----|----|----|----|----|----|-----------------------------|----------|-----------|-----------|----|----|---|-------------|----------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                       | 30          | 29 | 28 | 27 | 26                                                | 25 | 24 | 23          | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                          | 14       | 13        | 12        | 11 | 10 | 9 | 8           | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 |             |    |    |    |                                                   |    |    | test_rddata |    |    |    |    |    |    |    | test_rstn                   | test_clk | test_wren | test_addr |    |    |   | test_wrdata |                                  |   |   |   |   |   |   |   |
| Reset   | 0                        | 0           | 0  | 0  | 0  | 0                                                 | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0        | 0         | 0         | 0  | 0  | 0 | 0           | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access                   | Name        |    |    |    | Description                                       |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [31:24] | RO                       | reserved    |    |    |    | Reserved                                          |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [23:16] | RO                       | test_rddata |    |    |    | Data read signal of the debugging channel         |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [15]    | RW                       | test_rstn   |    |    |    | Reset signal of the debugging channel             |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [14]    | RW                       | test_clk    |    |    |    | Clock signal of the debugging channel             |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [13]    | RW                       | test_wren   |    |    |    | Read/Write enable signal of the debugging channel |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [12:8]  | RW                       | test_addr   |    |    |    | Address signal of the debugging channel           |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |
| [7:0]   | RW                       | test_wrdata |    |    |    | Data write signal of the debugging channel        |    |    |             |    |    |    |    |    |    |    |                             |          |           |           |    |    |   |             |                                  |   |   |   |   |   |   |   |



## CHIPSET\_INFO

CHIPSET\_INFO is a chip information register.

|        | Offset Address                                                                          | Register Name     | Total Reset Value                                 |
|--------|-----------------------------------------------------------------------------------------|-------------------|---------------------------------------------------|
| Bit    | 0x01E0                                                                                  | CHIPSET_INFO      | 0x0008_0000                                       |
| Name   | peri_chipset_info                                                                       |                   | dts_flag<br>reserved<br>dolby_flag                |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   1 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                   |                                                   |
| Bits   | Access                                                                                  | Name              | Description                                       |
| [31:3] | RO                                                                                      | peri_chipset_info | CA chipset_info[31:0]                             |
| [2]    | RO                                                                                      | dts_flag          | DTS support<br>0: not supported<br>1: supported   |
| [1]    | RO                                                                                      | reserved          | Reserved                                          |
| [0]    | RO                                                                                      | dolby_flag        | Dolby support<br>0: supported<br>1: not supported |

## PERI\_SW\_SET

PEIR\_SW\_SET is a software flag configuration register.

|        | Offset Address                                                                          | Register Name | Total Reset Value                       |
|--------|-----------------------------------------------------------------------------------------|---------------|-----------------------------------------|
| Bit    | 0x01F0                                                                                  | PERI_SW_SET   | 0x0000_0000                             |
| Name   | peri_sw_set                                                                             |               |                                         |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |               |                                         |
| Bits   | Access                                                                                  | Name          | Description                             |
| [31:0] | RW                                                                                      | peri_sw_set   | This register can be written only once. |

## PERI\_SIM\_OD\_CTRL

PERI\_SIM\_OD\_CTRL is an SCI pin output OD mode control register.



## **PERI\_FEPHY\_LDO\_CTRL**

**PERI\_FEPHY\_LDO\_CTRL** is an FE PHY LDO control register.

PERI\_CPU\_A7\_CFG

**PERI\_CPU\_A7\_CFG** is a CPU control register.



|        | Offset Address                                                                                      | Register Name   | Total Reset Value                                                                                                                     |
|--------|-----------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | 0x880                                                                                               | PERI_CPU_A7_CFG | 0x0000_0000                                                                                                                           |
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 |                 |                                                                                                                                       |
| Name   | reserved                                                                                            |                 | <b>l2rstdisable</b> <b>l1rstdisable3</b> <b>l1rstdisable2</b> <b>l1rstdisable1</b> <b>l1rstdisable0</b> reserved <b>func_mbist_en</b> |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                 |                                                                                                                                       |
| Bits   | Access                                                                                              | Name            | Description                                                                                                                           |
| [31:9] | RO                                                                                                  | reserved        | Reserved                                                                                                                              |
| [8]    | RW                                                                                                  | l2rstdisable    | Whether to invalidate the L2 cache automatically when reset on the A7 is deasserted<br>0x0: yes<br>0x1: no                            |
| [7]    | RW                                                                                                  | l1rstdisable3   | Whether to invalidate the L1 cache automatically when reset on the A7 core 3 is deasserted<br>0x0: yes<br>0x1: no                     |
| [6]    | RW                                                                                                  | l1rstdisable2   | Whether to invalidate the L1 cache automatically when reset on the A7 core 2 is deasserted<br>0x0: yes<br>0x1: no                     |
| [5]    | RW                                                                                                  | l1rstdisable1   | Whether to invalidate the L1 cache automatically when reset on the A7 core 1 is deasserted<br>0x0: yes<br>0x1: no                     |
| [4]    | RW                                                                                                  | l1rstdisable0   | Whether to invalidate the L1 cache automatically when reset on the A7 core 0 is deasserted<br>0x0: yes<br>0x1: no                     |
| [3:1]  | RO                                                                                                  | reserved        | Reserved                                                                                                                              |
| [0]    | RW                                                                                                  | func_mbist_en   | A7 function mbist enable<br>0x0: disabled<br>0x1: enabled                                                                             |



## PERI\_CPU\_A7\_STAT

PERI\_CPU\_A7\_STAT is a CPU status register.

|         | Offset Address                                                                                      | Register Name                                                                                             | Total Reset Value                                                                                                                                                                                                                                                                                                                                                                |
|---------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | PERI_CPU_A7_STAT                                                                                          | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                      |
| Name    | [31] l2_fun_mbist_tagram_fail<br>[30] l2_fun_mbist_dataram_fail                                     | core3_fun_mbist_ram_fail   core2_fun_mbist_ram_fail   core1_fun_mbist_ram_fail   core0_fun_mbist_ram_fail | fun_mbist_fail   fun_mbist_done                                                                                                                                                                                                                                                                                                                                                  |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                  |
| Bits    | Access                                                                                              | Name                                                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                      |
| [31]    | RO                                                                                                  | l2_fun_mbist_tagram_fail                                                                                  | L2 tagram function mbist error indicator<br>0x0: No error occurs.<br>0x1: Errors occur.                                                                                                                                                                                                                                                                                          |
| [30]    | RO                                                                                                  | l2_fun_mbist_dataram_fail                                                                                 | L2 dataram function mbist error indicator<br>0x0: No error occurs.<br>0x1: Errors occur.                                                                                                                                                                                                                                                                                         |
| [29:23] | RO                                                                                                  | core3_fun_mbist_ram_fail                                                                                  | RAM error indicator for core 3. The value 1 indicates that errors occur.<br>Bit 29: TLB ram error indicator<br>Bit 28: SCU tagram error indicator<br>Bit 27: L1 ddirty ram error indicator<br>Bit 26: L1 D-cache tagram error indicator<br>Bit 25: L1 D-cache dataram error indicator<br>Bit 24: L1 I-cache tagram error indicator<br>Bit 23: L1 I-cache dataram error indicator |
| [22:16] | RO                                                                                                  | core2_fun_mbist_ram_fail                                                                                  | RAM error indicator for core 2. The value 1 indicates that errors occur.<br>Bit 22: TLB ram error indicator<br>Bit 21: SCU tagram error indicator<br>Bit 20: L1 ddirty ram error indicator<br>Bit 19: L1 D-cache tagram error indicator<br>Bit 18: L1 D-cache dataram error indicator<br>Bit 17: L1 I-cache tagram error indicator<br>Bit 16: L1 I-cache dataram error indicator |



|        |    |                          |                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|----|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:9] | RO | core1_fun_mbist_ram_fail | RAM error indicator for core 1. The value 1 indicates that errors occur.<br>Bit 15: TLB ram error indicator<br>Bit 14: SCU tagram error indicator<br>Bit 13: L1 ddirty ram error indicator<br>Bit 12: L1 D-cache tagram error indicator<br>Bit 11: L1 D-cache dataram error indicator<br>Bit 10: L1 I-cache tagram error indicator<br>Bit 9: L1 I-cache dataram error indicator |
| [8:2]  | RO | core0_fun_mbist_ram_fail | RAM error indicator for core 0. The value 1 indicates that errors occur.<br>Bit 8: TLB ram error indicator<br>Bit 7: SCU tagram error indicator<br>Bit 6: L1 ddirty ram error indicator<br>Bit 5: L1 D-cache tagram error indicator<br>Bit 4: L1 D-cache dataram error indicator<br>Bit 3: L1 I-cache tagram error indicator<br>Bit 2: L1 I-cache dataram error indicator       |
| [1]    | RO | fun_mbist_fail           | A7 function mbist failure indicator<br>0x0: not failed<br>0x1: failed                                                                                                                                                                                                                                                                                                           |
| [0]    | RO | fun_mbist_done           | A7 function mbist completion indicator<br>0x0: not complete<br>0x1: complete                                                                                                                                                                                                                                                                                                    |

## PERI\_FE\_OD\_CTRL

PERI\_FE\_OD\_CTRL is an FE LED pin output OD mode control register.

|       | Offset Address |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    | Register Name   |    |    |    |    |    |   |   | Total Reset Value |   |   |   |                    |                   |   |   |
|-------|----------------|------|----|-------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|---|---|-------------------|---|---|---|--------------------|-------------------|---|---|
|       | 0x0890         |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    | PERI_FE_OD_CTRL |    |    |    |    |    |   |   | 0x0000_0000       |   |   |   |                    |                   |   |   |
| Bit   | 31             | 30   | 29 | 28          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3                  | 2                 | 1 | 0 |
| Name  | reserved       |      |    |             |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |                   |   |   |   | fe_led_base_od_sel | fe_led_act_od_sel |   |   |
| Reset | 0              | 0    | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0                  | 0                 |   |   |
| Bits  | Access         | Name |    | Description |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |   |   |                   |   |   |   |                    |                   |   |   |



|        |    |                    |                                                     |
|--------|----|--------------------|-----------------------------------------------------|
| [31:2] | RW | reserved           | Reserved                                            |
| [1]    | RW | fe_led_base_od_sel | Whether FE_LED_BASE is OD output<br>0: yes<br>1: no |
| [0]    | RW | fe_led_act_od_sel  | Whether FE_LED_ACT is OD output<br>0: yes<br>1: no  |

## 3.6 Interrupt System

Hi3796M V100 has the A7 and MCU interrupt systems.

Hi3796M V100 uses the GIC integrated in Cortex A7, which supports a maximum of 160 interrupt sources. [Table 3-46](#) describes the interrupt sources of Cortex A7.

**Table 3-46** Interrupt sources of Cortex A7

| No. | Interrupt Source |
|-----|------------------|
| 0   | COMMTX0          |
| 1   | COMMTX1          |
| 2   | COMMTX2          |
| 3   | COMMTX3          |
| 4   | COMMRX0          |
| 5   | COMM RX1         |
| 6   | COMM RX2         |
| 7   | COMM RX3         |
| 8   | PMU0             |
| 9   | PMU1             |
| 10  | PMU2             |
| 11  | PMU3             |
| 12  | Reserved         |
| 13  | Reserved         |
| 14  | Reserved         |
| 15  | Reserved         |
| 16  | Reserved         |



| No. | Interrupt Source      |
|-----|-----------------------|
| 17  | MCE                   |
| 18  | Reserved              |
| 19  | Reserved              |
| 20  | Reserved              |
| 21  | SWI0_PERI (A9)        |
| 22  | SWI1_PERI (A9)        |
| 23  | SWI2_PERI (A9)        |
| 24  | Timer 0 and timer 1   |
| 25  | Timer 2               |
| 26  | Timer 4               |
| 27  | Timer 6               |
| 28  | Timer 8/Timer 9 (SEC) |
| 29  | Watchdog 0            |
| 30  | DMAC                  |
| 31  | DDRC0                 |
| 32  | NANDC                 |
| 33  | Reserved              |
| 34  | SDIO0                 |
| 35  | SDIO1                 |
| 36  | SCI0                  |
| 37  | Reserved              |
| 38  | I <sup>2</sup> C0     |
| 39  | I <sup>2</sup> C1     |
| 40  | I <sup>2</sup> C2     |
| 41  | Reserved              |
| 42  | Reserved              |
| 43  | Reserved              |
| 44  | Reserved              |
| 45  | SSP0                  |
| 46  | Reserved              |
| 47  | IR                    |



| No. | Interrupt Source |
|-----|------------------|
| 48  | LEDC             |
| 49  | UART0            |
| 50  | UART1            |
| 51  | UART2            |
| 52  | Reserved         |
| 53  | Reserved         |
| 54  | Reserved         |
| 55  | Reserved         |
| 56  | Reserved         |
| 57  | Reserved         |
| 58  | Timer 3          |
| 59  | Timer 5          |
| 60  | Timer 7          |
| 61  | Reserved         |
| 62  | USB2HOST1_EHCI   |
| 63  | USB2HOST1_OHCI   |
| 64  | Reserved         |
| 65  | Reserved         |
| 66  | USB2HOST0_EHCI   |
| 67  | USB2HOST0_OHCI   |
| 68  | USB2OTG          |
| 69  | USB3             |
| 70  | Reserved         |
| 71  | ETH              |
| 72  | Reserved         |
| 73  | FE_PHY0          |
| 74  | Reserved         |
| 75  | Multiplexer      |
| 76  | Reserved         |
| 77  | Reserved         |
| 78  | AXI_SEC_INT      |



| No. | Interrupt Source |
|-----|------------------|
| 79  | Reserved         |
| 80  | Reserved         |
| 81  | Reserved         |
| 82  | PVR              |
| 83  | Reserved         |
| 84  | AIAO             |
| 85  | Reserved         |
| 86  | Reserved         |
| 87  | Reserved         |
| 88  | HDMI_TX          |
| 89  | Reserved         |
| 90  | VDP              |
| 91  | TDE              |
| 92  | Reserved         |
| 93  | VPSS0            |
| 94  | GPU              |
| 95  | VDH_NORM         |
| 96  | PGD              |
| 97  | JPGD0            |
| 98  | Reserved         |
| 99  | BPD              |
| 100 | Reserved         |
| 101 | VEDU             |
| 102 | JPGE             |
| 103 | Reserved         |
| 104 | SCD_NORM         |
| 105 | VDH_SAFE         |
| 106 | SCD_SAFE         |
| 107 | Reserved         |
| 108 | GPIO0            |
| 109 | GPIO1            |



| No. | Interrupt Source |
|-----|------------------|
| 110 | GPIO2            |
| 111 | GPIO3            |
| 112 | GPIO4            |
| 113 | GPIO5            |
| 114 | GPIO6            |
| 115 | Reserved         |
| 116 | Reserved         |
| 117 | Reserved         |
| 118 | Reserved         |
| 119 | Reserved         |
| 120 | Reserved         |
| 121 | Reserved         |
| 122 | Reserved         |
| 123 | Reserved         |
| 124 | Reserved         |
| 125 | Reserved         |
| 126 | SEC_INT_CIPHER   |
| 127 | INT_BPD_SAFE     |
| 128 | Reserved         |
| 129 | Reserved         |
| 130 | Reserved         |
| 131 | Reserved         |
| 132 | Reserved         |
| 133 | Reserved         |
| 134 | Reserved         |
| 135 | Reserved         |
| 136 | Reserved         |
| 137 | Reserved         |
| 138 | Reserved         |
| 139 | Reserved         |
| 140 | Reserved         |



| No. | Interrupt Source |
|-----|------------------|
| 141 | Reserved         |
| 142 | Reserved         |
| 143 | Reserved         |
| 144 | Reserved         |
| 145 | Reserved         |
| 146 | Reserved         |
| 147 | Reserved         |
| 148 | Reserved         |
| 149 | Reserved         |
| 150 | Reserved         |
| 151 | Reserved         |
| 152 | Reserved         |
| 153 | Reserved         |
| 154 | Reserved         |
| 155 | Reserved         |
| 156 | Reserved         |
| 157 | Reserved         |
| 158 | Reserved         |
| 159 | AXI_ERR_IRQ      |

The chip integrates the MCU, which supports a maximum of 32 interrupt sources, as described in [Table 3-47](#).

**Table 3-47** Interrupt sources of the MCU

| No. | Interrupt Source                                |
|-----|-------------------------------------------------|
| 0   | WDG                                             |
| 1   | Timer 0 and timer 1                             |
| 2   | UART1                                           |
| 3   | IR                                              |
| 4   | GPIO5/LEDC                                      |
| 5   | Timer 2/Timer 3/Timer 4/Timer 5/Timer 6/Timer 7 |
| 6   | UART0/UART2                                     |



| No. | Interrupt Source                                                                |
|-----|---------------------------------------------------------------------------------|
| 7   | GPIO0/GPIO1/GPIO2/GPIO3/GPIO4/GPIO6                                             |
| 8   | Reserved                                                                        |
| 9   | I <sup>2</sup> C0/I <sup>2</sup> C1/I <sup>2</sup> C2                           |
| 10  | SSP0                                                                            |
| 11  | Reserved                                                                        |
| 12  | SCI0                                                                            |
| 13  | Reserved                                                                        |
| 14  | Reserved                                                                        |
| 15  | SDIO0/SDIO1/NANDC                                                               |
| 16  | USB0_SUSPEND_RESUME/USB1_SUSPEND_RESUME/USB2_SUSPEND_RESUME/USB3_SUSPEND_RESUME |
| 17  | USB2HOST0_EHCI/USB2HOST0_OHCI/USB2OTG                                           |
| 18  | USB3DRD0                                                                        |
| 19  | Reserved                                                                        |
| 20  | ETH                                                                             |
| 21  | Reserved                                                                        |
| 22  | Multiplexer                                                                     |
| 23  | PVR                                                                             |
| 24  | PGD/JPGD/BPD                                                                    |
| 25  | VDH_SAFE/VDH_NORMAL/SCD_SAFE/SCD_NORMAL                                         |
| 26  | VEDU/JPGE                                                                       |
| 27  | VDP/VPSS0                                                                       |
| 28  | TDE/GPU                                                                         |
| 29  | AIAO/HDMI TX                                                                    |
| 30  | DMAC                                                                            |
| 31  | A7TOMCU soft interrupt                                                          |



## 3.7 Timer

### 3.7.1 Overview

The timer module implements the timing and counting functions. It not only provides system clocks for the operating system, but also is used by applications for timing and counting. The timer module has five submodules: dual-timer0, dual-timer 1, dual-timer 2, dual-timer 3, and dual-timer 4. Each dual-timer submodule consists of two timers with the same functions. Besides the different base addresses, the five dual-timer modules provide different functions in the system applications.

- Dual-timer 0 consists of timer 0 and timer 1, which share a base address and an interrupt signal.
- Dual-timer 1 consists of timer 2 and timer 3, which share a base address and an interrupt signal.
- Dual-timer 2 consists of timer 4 and timer 5, which use the same base address but different interrupt signals.
- Dual-timer 3 consists of timer 6 and timer 7, which use the same base address but different interrupt signals.
- Dual-timer 4 consists of timer 8 and timer 9, which share a base address and an interrupt signal.

### 3.7.2 Features

Each dual-timer module has the following features:

- Provides two 16-/32-bit down counters (each with a programmable 8-bit prescaler).
- Uses the crystal oscillator clock as the count clock.
- Supports three count modes: free-running mode, periodic mode, and one-shot mode.
- Loads the initial value by using the `TIMERx_LOAD` or `TIMERx_BGLOAD` register.
- Allows the current count value to be read at any time.
- Generates an interrupt when the current count value decreases to 0 if the interrupt function is enabled.

### 3.7.3 Function Description

#### Typical Application

The timers are provided for software. Each dual-timer submodule uses the fixed 24 MHz count clock. Timer 0 and timer 1 are not powered off in standby mode. They are dedicated for the MCU and cannot be used by the core. Timer 8 and timer 9 in dual-timer 4 share an interrupt signal. The other three timer submodules have the same features.

#### Function Implementation

The timer works based on a 16-bit or 32-bit (configurable) down counter. The count value decreases by 1 at the rising edge of each count clock. When the count value decreases to 0, the timer generates an interrupt if the interrupt function is enabled.

The timer supports three count modes:

- Free-running mode



The timer continuously counts. When the count value decreases to 0, the timer automatically returns to the maximum value and then continues to count. When the count length is 32 bits, the maximum value is 0xFFFF\_FFFF. When the count length is 16 bits, the maximum value is 0xFFFF. In free-running mode, a count value can be loaded, and the count value decreases immediately from the loaded value. When the count value decreases to 0, the maximum value is restored.

- Periodic mode

The timer continuously counts. When the count value decreases to 0, the timer loads the initial value from [TIMERx\\_BGLOAD](#) again and then continues to count.

- One-shot mode

The initial value is loaded to the timer. When the count value of the timer decreases to 0, the timer stops counting. The timer starts to count again only when a new value is loaded and the timer is enabled.

Each timer has a prescaler. The working clock of the prescaler can be divided by 1, 16, or 256 in the timer, which provides various frequencies for the count clock.

An initial value can be loaded to the timer in either of the following ways:

- Write to [TIMERx\\_LOAD](#) to load an initial count value to the timer. If the timer is working, the timer immediately recounts from the new value if a value is written to [TIMERx\\_LOAD](#). This method applies to all count modes.
- Write to [TIMERx\\_BGLOAD](#) to set the count cycle in periodic mode. If a value is written to [TIMERx\\_BGLOAD](#), the timer continues to count until the count value reaches 0, and then loads the written value from [TIMERx\\_BGLOAD](#) to count.

## 3.7.4 Working Process

### 3.7.4.1 Initializing the Timer

The timer must be initialized during system initialization. To initialize timer X ( $X = 0\text{--}9$ ), perform the following steps:

**Step 1** Configure [TIMERx\\_CONTROL](#) to set the timer count length.

**Step 2** Write to [TIMERx\\_LOAD](#) to load an initial value to the timer.

**Step 3** (Optional) If you want to enable the timer to work in periodic mode and the count cycle is different from the initial value loaded to the timer, write to [TIMERx\\_BGLOAD](#) to set the count cycle of the timer.

**Step 4** Configure [TIMERx\\_CONTROL](#) to set the count mode, prescaling divider, and interrupt mask of the timer, and then enable the timer to count.

----End

### 3.7.4.2 Handling Interrupts

The timer is used to generate interrupts periodically. Therefore, interrupt processing is a process of activating the processes that wait for the timing interrupt. The process is as follows:

**Step 1** Configure [TIMERx\\_INTCLR](#) to clear timer interrupts.

**Step 2** Activate the processes that wait for the interrupt.



**Step 3** When all the processes that wait for the interrupt are complete or enter the hibernate state, resume the interrupted program.

----End

## 3.7.5 Register Summary

Table 3-48 describes timer registers.

- Timer 0 and timer 1 share the base address 0xF800\_2000.
- Timer 2 and timer 3 share the base address 0xF8A2\_9000.
- Timer 4 and timer 5 share the base address 0xF8A2\_A000.
- Timer 6 and timer 7 share the base address 0xF8A2\_B000.
- Timer 8 and timer 9 share the base address 0xF8A8\_1000.

**NOTE**

The value of  $x$  in TIMER $x$  ranges from 0 to 9.

**Table 3-48** Summary of timer registers

| Offset Address | Register           | Description                                   | Page                  |
|----------------|--------------------|-----------------------------------------------|-----------------------|
| 0x000          | TIMER $x$ _LOAD    | Initial count value register                  | <a href="#">3-152</a> |
| 0x004          | TIMER $x$ _VALUE   | Current count value register                  | <a href="#">3-152</a> |
| 0x008          | TIMER $x$ _CONTROL | Timer control register                        | <a href="#">3-153</a> |
| 0x00C          | TIMER $x$ _INTCLR  | Interrupt clear register                      | <a href="#">3-156</a> |
| 0x010          | TIMER $x$ _RIS     | Raw interrupt register                        | <a href="#">3-156</a> |
| 0x014          | TIMER $x$ _MIS     | Masked interrupt register                     | <a href="#">3-157</a> |
| 0x018          | TIMER $x$ _BGLOAD  | Initial count value register in periodic mode | <a href="#">3-158</a> |

## 3.7.6 Register Description

### TIMER $x$ \_LOAD

TIMER $x$ \_LOAD is an initial count value register. It is used to set the initial count value of a timer. Each timer (timer 0–timer 9) has one such register.

When a timer is in periodic mode and the count value decreases to 0, the value of TIMER $x$ \_LOAD is reloaded to the counter. When a value is directly written to TIMER $x$ \_LOAD, the value of the current counter is changed to the written value on the next rising edge of the TIMCLK enabled by TIMCLKEN $x$ .

**NOTE**

- The minimum valid value written to TIMER $x$ \_LOAD is 1.
- When 0 is written to TIMER $x$ \_LOAD, the dual-timer submodule immediately generates an interrupt.



When a value is written to **TIMERx\_BGLOAD**, the value of **TIMERx\_LOAD** is overwritten, but the current value of the timer count is not affected.

If values are written to **TIMERx\_BGLOAD** and **TIMERx\_LOAD** before the rising edge of TIMCLK enabled by TIMCLKENx is reached, the value of the counter is changed to the written value of **TIMERx\_LOAD** at the next rising edge. From then on, when the counter reaches 0, the last value written to **TIMERx\_BGLOAD** or **TIMERx\_LOAD** is reloaded.

After **TIMERx\_BGLOAD** and **TIMERx\_LOAD** are written twice respectively, reading **TIMERx\_LOAD** returns the written value of **TIMERx\_BGLOAD**.

### 1. TIMER0\_LOAD

| Offset Address |        |             | Register Name |             |                                |   |   |   |   |   |   |   |   |   |   |   |   |   | Total Reset Value |             |   |   |   |   |   |   |   |   |
|----------------|--------|-------------|---------------|-------------|--------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|-------------------|-------------|---|---|---|---|---|---|---|---|
| Bit            | 0x000  |             |               | TIMER0_LOAD |                                |   |   |   |   |   |   |   |   |   |   |   |   |   |                   | 0x0000_0000 |   |   |   |   |   |   |   |   |
| Name           |        |             |               | timer0_load |                                |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0           | 0             | 0           | 0                              | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access | Name        |               |             | Description                    |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | timer0_load |               |             | Initial count value of timer 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |

### 2. TIMER1\_LOAD

| Offset Address |        |             | Register Name |             |                                |   |   |   |   |   |   |   |   |   |   |   |   |   | Total Reset Value |             |   |   |   |   |   |   |   |   |
|----------------|--------|-------------|---------------|-------------|--------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|-------------------|-------------|---|---|---|---|---|---|---|---|
| Bit            | 0x020  |             |               | TIMER1_LOAD |                                |   |   |   |   |   |   |   |   |   |   |   |   |   |                   | 0x0000_0000 |   |   |   |   |   |   |   |   |
| Name           |        |             |               | timer1_load |                                |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0           | 0             | 0           | 0                              | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access | Name        |               |             | Description                    |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |
| [31:0]         | RW     | timer1_load |               |             | Initial count value of timer 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |                   |             |   |   |   |   |   |   |   |   |

## TIMERx\_VALUE

**TIMERx\_VALUE** is a current count value register. It provides the current value of the counter that is counting down.

Each timer (timer 0–timer 9) has one such register.

After a value is written to **TIMERx\_LOAD**, **TIMERx\_VALUE** immediately reflects the newly loaded value of the counter in the PCLK domain without waiting for the next clock edge of the TIMCLK enabled by TIMCLKENx.

### NOTE

When a timer is in 16-bit mode, the upper 16 bits of the 32-bit **TIMERx\_VALUE** are not automatically set to 0. If **TIMERx\_LOAD** is never written after the timer is switched from 32-bit mode to 16-bit mode, the upper 16 bits of **TIMERx\_VALUE** may be non-zero values.



### 1. TIMER0\_VALUE

| Offset Address |              |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|--------------|--------------|----|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x004          |              |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    | TIMER0_VALUE  |    |    |    |    |    |    |   | 0xFFFF_FFFF       |   |   |   |   |   |   |   |   |
| Bit            | 31           | 30           | 29 | 28                                                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | timer0_value |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 1            | 1            | 1  | 1                                                    | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1             | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1                 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |
| Bits           | Access       | Name         |    | Description                                          |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RO           | timer0_value |    | Current count value of timer 0 that is counting down |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

### 2. TIMER1\_VALUE

| Offset Address |              |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|--------------|--------------|----|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x024          |              |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    | TIMER1_VALUE  |    |    |    |    |    |    |   | 0xFFFF_FFFF       |   |   |   |   |   |   |   |   |
| Bit            | 31           | 30           | 29 | 28                                                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | timer0_value |              |    |                                                      |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 1            | 1            | 1  | 1                                                    | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1             | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1                 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |
| Bits           | Access       | Name         |    | Description                                          |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RO           | timer0_value |    | Current count value of timer 1 that is counting down |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## TIMERx\_CONTROL

TIMERx\_CONTROL is a timer control register. Each timer (timer 0–timer 9) has one such register.

### NOTE

When the periodic mode is selected, TIMERx\_CONTROL[timermode] must be set to 1 and TIMERx\_CONTROL[oneshot] must be set to 0.



## 1. TIMER0\_CONTROL

| Offset Address |          |           |    |                                                                                                                                                                                                                                                                                                          |    |    |    |    |    |    |    | Register Name  |    |    |    |    |    |    |    |    |    |    |   | Total Reset Value |         |           |           |          |          |           |         |   |  |  |  |
|----------------|----------|-----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----------------|----|----|----|----|----|----|----|----|----|----|---|-------------------|---------|-----------|-----------|----------|----------|-----------|---------|---|--|--|--|
| 0x008          |          |           |    |                                                                                                                                                                                                                                                                                                          |    |    |    |    |    |    |    | TIMER0_CONTROL |    |    |    |    |    |    |    |    |    |    |   | 0x0000_0020       |         |           |           |          |          |           |         |   |  |  |  |
| Bit            | 31       | 30        | 29 | 28                                                                                                                                                                                                                                                                                                       | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20             | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7       | 6         | 5         | 4        | 3        | 2         | 1       | 0 |  |  |  |
| Name           | reserved |           |    |                                                                                                                                                                                                                                                                                                          |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   | timeren | timermode | intenable | reserved | timerpre | timersize | oneshot |   |  |  |  |
| Reset          | 0        | 0         | 0  | 0                                                                                                                                                                                                                                                                                                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0       | 1         | 0         | 0        | 0        | 0         | 0       |   |  |  |  |
| Bits           | Access   | Name      |    | Description                                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [31:8]         | -        | reserved  |    | Reserved                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [7]            | RW       | timeren   |    | Timer enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [6]            | RW       | timermode |    | Timer count mode<br>0: free-running mode<br>1: periodic mode                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [5]            | RW       | intenable |    | TIMERx_RIS interrupt mask<br>0: masked<br>1: not masked                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [4]            | -        | reserved  |    | Reserved                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [3:2]          | RW       | timerpre  |    | Timer prescaling divider<br>00: no prescaling. That is, the clock frequency of the timer is divided by 1.<br>01: 4-level prescaling. That is, the clock frequency of the timer is divided by 16.<br>10: 8-level prescaling. That is, the clock frequency of the timer is divided by 256.<br>11: reserved |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [1]            | RW       | timersize |    | Counter select<br>0: 16-bit counter<br>1: 32-bit counter                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |
| [0]            | RW       | oneshot   |    | Count mode<br>0: periodic mode or free-running mode<br>1: one-shot mode                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |    |    |   |                   |         |           |           |          |          |           |         |   |  |  |  |



## 2. TIMER1\_CONTROL



## TIMERx\_INTCLR

TIMERx\_INTCLR is an interrupt clear register. Writing any value to this register clears the interrupt status of the counter. Each timer (timer 0–timer 9) has one such register.



### CAUTION

This register is write-only. When a value is written to this register, the timer interrupts are cleared. No written value is recorded in this register and no default reset value is defined.

#### 1. TIMER0\_INTCLR

|        | Offset Address |               |    |                                                                   |    |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----------------|---------------|----|-------------------------------------------------------------------|----|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|        | 0x00C          |               |    |                                                                   |    |    |    |    | TIMER0_INTCLR |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit    | 31             | 30            | 29 | 28                                                                | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | timer0_intclr  |               |    |                                                                   |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset  | 0              | 0             | 0  | 0                                                                 | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits   | Access         | Name          |    | Description                                                       |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0] | WO             | timer0_intclr |    | Writing to this register clears the output interrupts of timer 0. |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### 2. TIMER1\_INTCLR

|        | Offset Address |               |    |                                                                   |    |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----------------|---------------|----|-------------------------------------------------------------------|----|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|        | 0x02C          |               |    |                                                                   |    |    |    |    | TIMER1_INTCLR |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit    | 31             | 30            | 29 | 28                                                                | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | timer1_intclr  |               |    |                                                                   |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset  | 0              | 0             | 0  | 0                                                                 | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits   | Access         | Name          |    | Description                                                       |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0] | WO             | timer1_intclr |    | Writing to this register clears the output interrupts of timer 1. |    |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## TIMERx\_RIS

TIMERx\_RIS is a raw interrupt status register. Each timer (timer 0–timer 9) has one such register.



## 1. TIMER0\_RIS

| Offset Address |          |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |           |   |   |   |
|----------------|----------|-----------|----|---------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|-----------|---|---|---|
| 0x010          |          |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | TIMER0_RIS    |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |           |   |   |   |
| Bit            | 31       | 30        | 29 | 28                                                                                                | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3         | 2 | 1 | 0 |
| Name           | reserved |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   | timer0ris |   |   |   |
| Reset          | 0        | 0         | 0  | 0                                                                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0         | 0 |   |   |
| Bits           | Access   | Name      |    | Description                                                                                       |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |
| [31:1]         | -        | reserved  |    | Reserved<br>Writing to this field has no effect and reading this field returns 0.                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |
| [0]            | RO       | timer0ris |    | Raw interrupt status of timer 0<br>0: No interrupt is generated.<br>1: An interrupt is generated. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |

## 2. TIMER1\_RIS

| Offset Address |          |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |           |   |   |   |
|----------------|----------|-----------|----|---------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|-----------|---|---|---|
| 0x030          |          |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | TIMER1_RIS    |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |           |   |   |   |
| Bit            | 31       | 30        | 29 | 28                                                                                                | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3         | 2 | 1 | 0 |
| Name           | reserved |           |    |                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   | timer1ris |   |   |   |
| Reset          | 0        | 0         | 0  | 0                                                                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0         | 0 |   |   |
| Bits           | Access   | Name      |    | Description                                                                                       |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |
| [31:1]         | -        | reserved  |    | Reserved<br>Writing to this field has no effect and reading this field returns 0.                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |
| [0]            | RO       | timer1ris |    | Raw interrupt status of timer 1<br>0: No interrupt is generated.<br>1: An interrupt is generated. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |           |   |   |   |

## TIMERx\_MIS

TIMERx\_MIS is a masked interrupt status register. Each timer (timer 0–timer 9) has one such register.



### 1. TIMER0\_MIS

| Offset Address |          |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |           |   |   |
|----------------|----------|-----------|----|--------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|-----------|---|---|
| 0x014          |          |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    | TIMER0_MIS    |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |           |   |   |
| Bit            | 31       | 30        | 29 | 28                                                                                               | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2         | 1 | 0 |
| Name           | reserved |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   | timer0mis |   |   |
| Reset          | 0        | 0         | 0  | 0                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0         |   |   |
| Bits           | Access   | Name      |    | Description                                                                                      |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |
| [31:1]         | -        | reserved  |    | Reserved                                                                                         |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |
| [0]            | RO       | timer0mis |    | Masked interrupt status of timer 0<br>0: The interrupt is invalid.<br>1: The interrupt is valid. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |

### 2. TIMER1\_MIS

| Offset Address |          |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |           |   |   |
|----------------|----------|-----------|----|--------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|-----------|---|---|
| 0x034          |          |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    | TIMER1_MIS    |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |           |   |   |
| Bit            | 31       | 30        | 29 | 28                                                                                               | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2         | 1 | 0 |
| Name           | reserved |           |    |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   | timer1mis |   |   |
| Reset          | 0        | 0         | 0  | 0                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0         |   |   |
| Bits           | Access   | Name      |    | Description                                                                                      |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |
| [31:1]         | -        | reserved  |    | Reserved                                                                                         |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |
| [0]            | RO       | timer1mis |    | Masked interrupt status of timer 1<br>0: The interrupt is invalid.<br>1: The interrupt is valid. |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |           |   |   |

## TIMERx\_BGLOAD

TIMERx\_BGLOAD is an initial count value register in periodic mode. Each timer (timer 0–timer 9) has one such register.

This register contains the initial count value of the timer. In periodic mode, this register is used to reload the initial count value when the count value of the timer reaches 0.



This register provides another way for accessing TIMERx\_LOAD. After a value is written to TIMERx\_BGLOAD, the timer, however, does not count starting from the new written value immediately.

### 1. TIMER0\_BGLOAD

| Offset Address |              |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |  |  |
|----------------|--------------|--------------|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|--|--|
| 0x018          |              |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    | TIMER0_BGLOAD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |   |  |  |
| Bit            | 31           | 30           | 29 | 28 | 27 | 26                                                                                                                                   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |   |   |   |   |   |  |  |
| Name           | timer0bgload |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |
| Reset          | 0            | 0            | 0  | 0  | 0  | 0                                                                                                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 |  |  |
| Bits           | Access       | Name         |    |    |    | Description                                                                                                                          |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |
| [31:0]         | RW           | timer0bgload |    |    |    | Initial count value of timer 0<br><br>Note: This register differs from TIMER0_LOAD. For details, see the description of TIMERX_LOAD. |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |

### 2. TIMER1\_BGLOAD

| Offset Address |              |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |  |  |
|----------------|--------------|--------------|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|--|--|
| 0x038          |              |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    | TIMER1_BGLOAD |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |   |  |  |
| Bit            | 31           | 30           | 29 | 28 | 27 | 26                                                                                                                                   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |   |   |   |   |   |  |  |
| Name           | timer1bgload |              |    |    |    |                                                                                                                                      |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |
| Reset          | 0            | 0            | 0  | 0  | 0  | 0                                                                                                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 |  |  |
| Bits           | Access       | Name         |    |    |    | Description                                                                                                                          |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |
| [31:0]         | RW           | timer1bgload |    |    |    | Initial count value of timer 1<br><br>Note: This register differs from TIMER1_LOAD. For details, see the description of TIMERX_LOAD. |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |  |  |

## 3.8 DMA Controller

### 3.8.1 Overview

DMA refers to an operating mode in which I/O data is exchanged by the hardware. In this mode, the DMAC directly transfers data between a memory and a peripheral, between peripherals, or between memories. This avoids the processor intervention and reduces the interrupt handling overhead of the processor. The DMA mode is usually used to transmit data blocks at high speed. After receiving a DMA request, the DMAC enables the bus master controller based on the channel configured by the CPU and sends the address and control signals to the memory and peripherals. The DMAC counts the transmitted data and reports the status of data transfer (data transfer completion or error) to the CPU by using interrupts.



### 3.8.2 Features

The DMAC has the following features:

- Transfers data in 8-bit, 16-bit, or 32-bit mode.
- Provides four DMA channels. Each channel can be configured for a certain unidirectional transfer.
- Provides fixed DMA channel priorities. DMA channel 0 has the highest priority; whereas channel 3 has the lowest priority. When valid DMA requests from two peripherals are received simultaneously, the channel with the higher priority starts data transfer first.
- Provides a 4 x 32-bit FIFO in each channel of DMAC channels 0 to 3.
- Provides two 32-bit master bus interfaces for data transfer.
- Supports two types of DMA requests for peripherals: single transfer request and burst transfer request.
- Provides 16 groups of DMA request inputs. These requests can be configured as source requests or destination requests.
- Supports the DMA requests controlled by software.
- Programs the DMA burst size.
- Configures the source address and the destination address as automatic incremental or decremental addresses during DMA transfer.
- Supports four data transfer directions:
  - Memory to peripheral
  - Memory to memory
  - Peripheral to memory
  - Peripheral to peripheral
- Supports DMA transfer with the linked list.
- Supports the DMAC flow control.
- Provides a maskable interrupt output and supports the query of the states of the raw/masked DMA error interrupt and DMA transfer completion interrupt and the state of the combination of the two interrupts.
- Controls the power consumption by disabling the DMAC and supports DMAC clock gating.

### 3.8.3 Function Description

#### Function Block Diagram

[Figure 3-3](#) shows the functional block diagram of the DMAC.

**Figure 3-3** Functional block diagram of the DMAC

Each DMAC channel involves a group of transfer control logic and one FIFO. The transfer control logic performs the following operations automatically:

- Step 1** Read data from the source address specified by the software.
- Step 2** Buffer the data to the FIFO.
- Step 3** Fetch data from the FIFO.
- Step 4** Write the data to the destination address specified by the software.

----End

## Working Process

The workflow of the DMAC is as follows:

- Step 1** The software selects one DMAC channel for DMA transfer, configures the following items, and enables the channel:
  - Source address
  - Destination address
  - Head pointer of the linked list
  - Amount of the transferred data
  - Source and destination peripheral request signal numbers
  - Masters used at the source and destination ends of the channel.

After the channel is enabled, the DMAC starts to check the activities of the DMA request signals between the source peripheral and destination device connected to this channel.

- Step 2** The source device transmits a DMA request to the DMAC. If the source device is a memory, the DMAC considers that the DMA request is always valid by default.

- Step 3** The DMAC channel responds to the DMA request of the source device, reads data from the source device, and stores the data to the internal FIFO of the channel.
- Step 4** The destination device sends a DMA request to the DMAC. If the destination device is a memory, the DMAC considers that the DMA request is always valid by default.
- Step 5** The DMAC channel responds to the DMA request of the destination device, fetches data from the internal FIFO of the channel, and writes it to the destination device.

Steps 2 and 3 and steps 4 and 5 may be performed concurrently, because the source and destination devices may initiate DMA requests to the DMAC at the same time. When the FIFO overrun or underrun occurs on the DMA channel, the DMAC blocks the DMA requests of the source device or destination device until the FIFO is not full or empty. When the DMAC interacts with the source device and destination device, step 2 to step 5 are performed repeatedly until the specified data is transferred and a transfer completion interrupt (maskable) is generated. If the value of [DMAC\\_CXLLI](#) is not 0, read linked list item (LLI) nodes by considering the value of [DMAC\\_CXLLI](#) as an address, load the read values to [DMAC\\_CX\\_SRC\\_ADDR](#), [DMAC\\_CX\\_DEST\\_ADDR](#), [DMAC\\_CXLLI](#), and [DMAC\\_CX\\_CONTROL](#) in sequence (see [Figure 3-4](#)), and then go to step 2. If the value of [DMAC\\_CXLLI](#) is 0, the current DMA transfer is stopped. In this case, the channel is disabled automatically and the data transfer ends.

----End

[Figure 3-4](#) shows how to update channel registers by using LLI.

**Figure 3-4** Updating channel registers by using LLI



## Connection Between the DMAC and Peripherals

The peripherals initiate data transfer by transmitting DMA request signals to the DMAC.

The DMAC provides two types of DMA request signals for each peripheral:

- DMACBREQ

Burst transfer request signal. It triggers a burst transfer and the burst size is preconfigured.

- DMACSREQ

Single transfer request signal. It triggers a single transfer. That is, the DMAC reads a data segment from a peripheral or writes a data segment to a peripheral.

The DMAC provides a request clear signal DMACLR. This signal is sent to each peripheral by the DMAC as response to the DMA request signal of each peripheral.

[Figure 3-5](#) shows the connections between the DMAC and other modules.

**Figure 3-5** Connections between the DMAC and other modules



### 3.8.4 Operating Mode

#### Clock Gating

The DMAC and DMAC clock can be disabled using software in the following scenarios to reduce power consumption:

- All DMAC channels are idle and there is no DMA transfer request.
- [DMAC\\_CX\\_CONFIG\[e\]](#) is set to 0 and the DMAC channel is disabled.

To disable the DMAC clock, perform the following steps:

**Step 1** Write 0 to [DMAC\\_CX\\_CONFIG\[e\]](#) to disable DMAC channels.

**Step 2** Write 0 to [DMAC\\_CONFIG\[e\]](#) to disable the DMAC.

**Step 3** Write 0 to [PERI\\_CRG33\[dma\\_cken\]](#) to disable the DMAC clock.

Enable the clock and the DMAC again when the DMAC is required for data transfer.

**----End**

#### Initializing the IDMAC

To initialize the DMAC, perform the following steps:



- Step 1** Write to **DMAC\_CONFIG** to set the endianness of DMAC master 1 and DMAC master 2, and write 1 to **DMAC\_CONFIG[e]** to enable the DMAC.
- Step 2** Write 1 to all the bits of **DMAC\_INT\_ERR\_CLR** and **DMAC\_INT\_TC\_CLR** to clear all interrupts.
- Step 3** Write 0 to the corresponding bits of **DMAC\_SYNC** to set the DMA request signal groups to be synchronized.
- Step 4** Configure and disable each channel in sequence by writing 0 to **DMAC\_CX\_CONFIG[e]** of each channel.

----End

## Enabling a Channel

After the DMAC is initialized, it can transmit data only when a DMAC channel is configured and enabled. To enable a DMA channel, perform the following steps:

- Step 1** Read **DMAC\_ENBLD\_CHNS** to search for idle channels and select one.
- Step 2** Write 1 to the corresponding bits of **DMAC\_INT\_ERR\_CLR** and **DMAC\_INT\_TC\_CLR** to clear the interrupt status of the selected channel.
- Step 3** Configure and enable the selected channel as follows:
1. Write to **DMAC\_CX\_SRC\_ADDR** to set the access start address of the source device.
  2. Write to **DMAC\_CX\_DEST\_ADDR** to set the access start address of the destination device.
  3. For single-block data transfer, write 0 to **DMAC\_CXLLI**.
  4. For LLI data transfer, set **DMAC\_CXLLI** to the LLI header pointer.
  5. Write to **DMAC\_CX\_CONTROL** to set the master, data width, burst size, address increment, and transfer size of the source device and destination device.
  6. Write to **DMAC\_CX\_CONFIG** to set the DMA request signal, flow control mode, and interrupt mask of the channel. At this time, write 0 to **DMAC\_CX\_CONFIG[e]**, that is, this channel is not enabled currently.
  7. Write to **DMAC\_CX\_CONFIG** to enable this channel. Set the Channel Enable bit to 1 and keep other bits unchanged.

----End

## Handling Interrupts

When data transfer is complete or an error occurs during data transfer, an interrupt is reported to the interrupt controller. The interrupt is handled as follows:

- Step 1** Read **DMAC\_INT\_STAT** to find the channel that transmits an interrupt request. When multiple channels initiate interrupt requests at the same time, the interrupt request with the highest priority is handled first.
- Step 2** Read **DMAC\_INT\_TC\_STAT** to query the value of the selected bit to check whether the interrupt sent by the corresponding channel is a transfer completion interrupt. If the value is 1, the interrupt is a transfer completion interrupt. In this case, go to step 4; otherwise, go to step 3.



**Step 3** Read **DMAC\_INT\_ERR\_STAT** to query the value of the selected bit to check whether the interrupt sent by the corresponding channel is an error interrupt. If the selected bit is 1, the interrupt is an error interrupt. In this case, go to step 5; otherwise, end the operation.

**Step 4** Handle the transfer completion interrupt as follows:

1. Write 1 to the selected bit of **DMAC\_INT\_TC\_CLR** to clear the interrupt status of the corresponding channel.
2. Fetch or use up the data buffered in the memory. If necessary (for example, a buffer needs to be created in the memory), configure and enable the channel again.
3. End interrupt operations.

Handle the error interrupt as follows:

1. Write 1 to the selected bit of **DMAC\_INT\_ERR\_CLR** to clear the interrupt status of the corresponding channel.
2. Provide the error information. If necessary, configure and enable the channel again.
3. End interrupt operations.

----End

### 3.8.5 Register Summary

Table 3-49 describes the DMAC registers.



The variable *X* in the offset addresses of registers indicates the channel ID and ranges from 0 to 3.

**Table 3-49** Summary of DMAC registers (base address: 0xF987\_0000)

| Offset Address | Register                | Description                                        | Page                  |
|----------------|-------------------------|----------------------------------------------------|-----------------------|
| 0x000          | DMAC_INT_STAT           | Interrupt status register                          | <a href="#">3-166</a> |
| 0x004          | DMAC_INT_TC_STAT        | DMAC transfer completion interrupt status register | <a href="#">3-167</a> |
| 0x008          | DMAC_INT_TC_CLR         | Transfer completion status clear register          | <a href="#">3-167</a> |
| 0x00C          | DMAC_INT_ERR_STAT       | Error interrupt status register                    | <a href="#">3-168</a> |
| 0x010          | DMAC_INT_ERR_CLR        | Error interrupt clear register                     | <a href="#">3-168</a> |
| 0x014          | DMAC_RAW_INT_TC_STATUS  | Raw transfer completion interrupt status register  | <a href="#">3-168</a> |
| 0x018          | DMAC_RAW_INT_ERR_STATUS | Raw transfer error interrupt status register       | <a href="#">3-169</a> |
| 0x01C          | DMAC_ENBLD_CHNS         | Channel enable register                            | <a href="#">3-169</a> |
| 0x020          | DMAC_SOFT_BREQ          | Software burst request register                    | <a href="#">3-170</a> |
| 0x024          | DMAC_SOFT_SREQ          | Software single request register                   | <a href="#">3-171</a> |



| Offset Address   | Register          | Description                           | Page                  |
|------------------|-------------------|---------------------------------------|-----------------------|
| 0x028            | DMAC_SOFT_LBREQ   | Software last burst request register  | <a href="#">3-171</a> |
| 0x02C            | DMAC_SOFT_LSREQ   | Software last single request register | <a href="#">3-172</a> |
| 0x030            | DMAC_CONFIG       | Configuration register                | <a href="#">3-172</a> |
| 0x034            | DMAC_SYNC         | Sync register                         | <a href="#">3-173</a> |
| 0x100 + X x 0x20 | DMAC_CX_SRC_ADDR  | DMAC source address register          | <a href="#">3-174</a> |
| 0x104 + X x 0x20 | DMAC_CX_DEST_ADDR | DMAC destination address register     | <a href="#">3-174</a> |
| 0x108 + X x 0x20 | DMAC_CXLLI        | DMAC LLI register                     | <a href="#">3-175</a> |
| 0x10C + X x 0x20 | DMAC_CX_CONTROL   | Channel control register              | <a href="#">3-176</a> |
| 0x110 + X x 0x20 | DMAC_CX_CONFIG    | Channel configuration register        | <a href="#">3-181</a> |

### 3.8.6 Register Description

#### DMAC\_INT\_STAT

DMAC\_INT\_STAT is an interrupt status register. It shows the masked DMAC interrupt status. If certain bits of DMAC\_INT\_TC\_STAT and DMAC\_INT\_ERR\_STAT are masked at the same time, the corresponding bit of DMAC\_INT\_STAT is also masked. Each bit of DMAC\_INT\_STAT maps to one DMAC channel. When a bit is 1, an interrupt request is generated in the corresponding channel and the interrupt request may be an error interrupt or a transfer completion interrupt.

|        | Offset Address                                                                                      | Register Name | Total Reset Value                                                                                                                                                                                                                |
|--------|-----------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit    | 0x000                                                                                               | DMAC_INT_STAT | 0x0000_0000                                                                                                                                                                                                                      |
| Name   | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | reserved      | int_stat                                                                                                                                                                                                                         |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |               |                                                                                                                                                                                                                                  |
| Bits   | Access                                                                                              | Name          | Description                                                                                                                                                                                                                      |
| [31:4] | -                                                                                                   | reserved      | Reserved                                                                                                                                                                                                                         |
| [3:0]  | RO                                                                                                  | int_stat      | Masked interrupt status of each DMA channel. Bit[3:0] map to channels 3–0.<br>0: No interrupt is generated.<br>1: An interrupt is generated. The interrupt request may be an error interrupt or a transfer completion interrupt. |



## DMAC\_INT\_TC\_STAT

DMAC\_INT\_TC\_STAT is a transfer completion interrupt status register. It shows the status of the masked transfer completion interrupts. The corresponding mask bit is DMAC\_CX\_CONFIG[itc], where X is the channel number ranging from 0 to 3. This register must work with the DMAC\_INT\_STAT register.

| Offset Address |          |             |    |    |                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    | Register Name    |    |    |    |    |    |    |   | Total Reset Value |             |   |   |   |   |   |   |   |
|----------------|----------|-------------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|---|-------------------|-------------|---|---|---|---|---|---|---|
| 0x004          |          |             |    |    |                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    | DMAC_INT_TC_STAT |    |    |    |    |    |    |   | 0x0000_0000       |             |   |   |   |   |   |   |   |
| Bit            | 31       | 30          | 29 | 28 | 27                                                                                                                                                                                  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |             |    |    |                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   | int_tc_stat |   |   |   |   |   |   |   |
| Reset          | 0        | 0           | 0  | 0  | 0                                                                                                                                                                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name        |    |    | Description                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |
| [31:4]         | -        | reserved    |    |    | Reserved                                                                                                                                                                            |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |
| [3:0]          | RO       | int_tc_stat |    |    | Masked transfer completion interrupt status. Bit[3:0] map to channels 3–0.<br>0: No transfer completion interrupt is generated.<br>1: A transfer completion interrupt is generated. |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |

## DMAC\_INT\_TC\_CLR

DMAC\_INT\_TC\_CLR is a transfer completion interrupt clear register. It is used to clear transfer completion interrupts.

| Offset Address |          |            |    |    |                                                                                                    |    |    |    |    |    |    |    |    |    |    | Register Name   |    |    |    |    |    |    |   | Total Reset Value |   |            |   |   |   |   |   |   |
|----------------|----------|------------|----|----|----------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|---|-------------------|---|------------|---|---|---|---|---|---|
| 0x008          |          |            |    |    |                                                                                                    |    |    |    |    |    |    |    |    |    |    | DMAC_INT_TC_CLR |    |    |    |    |    |    |   | 0x0000_0000       |   |            |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27                                                                                                 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    |                                                                                                    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |   |                   |   | int_tc_clr |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0                                                                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0          | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name       |    |    | Description                                                                                        |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |   |                   |   |            |   |   |   |   |   |   |
| [31:4]         | -        | reserved   |    |    | Reserved                                                                                           |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |   |                   |   |            |   |   |   |   |   |   |
| [3:0]          | WO       | int_tc_clr |    |    | Transfer completion interrupt clear. Bit[3:0] map to channels 3–0.<br>0: not cleared<br>1: cleared |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |   |                   |   |            |   |   |   |   |   |   |



## DMAC\_INT\_ERR\_STAT

DMAC\_INT\_ERR\_STAT is an error interrupt status register. It shows the masked error interrupt status. The corresponding mask bit is DMAC\_CX\_CONFIG[ie].

| Offset Address |        |              |   |   |                                                                                                                                            |   |   |   |   |   |   |   |   |   |   | Register Name     |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |   |  |
|----------------|--------|--------------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|---|--|
| Bit            | 0x00C  |              |   |   |                                                                                                                                            |   |   |   |   |   |   |   |   |   |   | DMAC_INT_ERR_STAT |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |   |   |  |
| Name           |        |              |   |   |                                                                                                                                            |   |   |   |   |   |   |   |   |   |   | reserved          |   |   |   |   |   |   |   | int_err_stat      |   |   |   |   |   |   |  |
| Reset          | 0      | 0            | 0 | 0 | 0                                                                                                                                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Bits           | Access | Name         |   |   | Description                                                                                                                                |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |
| [31:4]         | -      | reserved     |   |   | Reserved                                                                                                                                   |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |
| [3:0]          | RO     | int_err_stat |   |   | Masked error interrupt status. Bit[3:0] map to channels 3–0.<br>0: No error interrupt is generated.<br>1: An error interrupt is generated. |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |

## DMAC\_INT\_ERR\_CLR

DMAC\_INT\_ERR\_CLR is an error interrupt clear register. It is used to clear error interrupts.

| Offset Address |        |             |   |   |                                                                                      |   |   |   |   |   |   |   |   |   |   | Register Name    |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |   |  |
|----------------|--------|-------------|---|---|--------------------------------------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|------------------|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|---|--|
| Bit            | 0x010  |             |   |   |                                                                                      |   |   |   |   |   |   |   |   |   |   | DMAC_INT_ERR_CLR |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |   |   |  |
| Name           |        |             |   |   |                                                                                      |   |   |   |   |   |   |   |   |   |   | reserved         |   |   |   |   |   |   |   | int_err_clr       |   |   |   |   |   |   |  |
| Reset          | 0      | 0           | 0 | 0 | 0                                                                                    | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Bits           | Access | Name        |   |   | Description                                                                          |   |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |
| [31:4]         | -      | reserved    |   |   | Reserved                                                                             |   |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |
| [3:0]          | WO     | int_err_clr |   |   | Error interrupt clear. Bit[3:0] map to channels 3–0.<br>0: not cleared<br>1: cleared |   |   |   |   |   |   |   |   |   |   |                  |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |  |

## DMAC\_RAW\_INT\_TC\_STATUS

DMAC\_RAW\_INT\_TC\_STATUS is a raw transfer completion interrupt status register. It shows the status of the raw transfer completion interrupt of each channel.



| Offset Address |          |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    | Register Name          |    |    |    |    |    |    |   | Total Reset Value |   |                 |   |   |   |   |   |   |
|----------------|----------|-----------------|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|----|---|-------------------|---|-----------------|---|---|---|---|---|---|
| 0x014          |          |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    | DMAC_RAW_INT_TC_STATUS |    |    |    |    |    |    |   | 0x0000_0000       |   |                 |   |   |   |   |   |   |
| Bit            | 31       | 30              | 29 | 28 | 27                                                                                                                                                                               | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6               | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                 |    |    |                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |    |   |                   |   | raw_int_tc_stat |   |   |   |   |   |   |
| Reset          | 0        | 0               | 0  | 0  | 0                                                                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0               | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name            |    |    | Description                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |    |   |                   |   |                 |   |   |   |   |   |   |
| [31:4]         | -        | reserved        |    |    | Reserved                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |    |   |                   |   |                 |   |   |   |   |   |   |
| [3:0]          | RO       | raw_int_tc_stat |    |    | Raw transfer completion interrupt status. Bit[3:0] map to channels 3–0.<br>0: No transfer completion interrupt is generated.<br>1: A transfer completion interrupt is generated. |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |    |   |                   |   |                 |   |   |   |   |   |   |

## DMAC\_RAW\_INT\_ERR\_STATUS

DMAC\_RAW\_INT\_ERR\_STATUS is a raw error interrupt status register. It shows the status of the raw error interrupt of each channel.

| Offset Address |          |                  |    |    |                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    | Register Name           |    |    |    |    |    |    |   | Total Reset Value |   |                  |   |   |   |   |   |   |
|----------------|----------|------------------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|---|-------------------|---|------------------|---|---|---|---|---|---|
| 0x018          |          |                  |    |    |                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    | DMAC_RAW_INT_ERR_STATUS |    |    |    |    |    |    |   | 0x0000_0000       |   |                  |   |   |   |   |   |   |
| Bit            | 31       | 30               | 29 | 28 | 27                                                                                                                                                      | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6                | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                  |    |    |                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   | raw_int_err_stat |   |   |   |   |   |   |
| Reset          | 0        | 0                | 0  | 0  | 0                                                                                                                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0                | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name             |    |    | Description                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                  |   |   |   |   |   |   |
| [31:4]         | -        | reserved         |    |    | Reserved                                                                                                                                                |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                  |   |   |   |   |   |   |
| [3:0]          | RO       | raw_int_err_stat |    |    | Raw error interrupt status of each channel. Bit[3:0] map to channels 3–0.<br>0: No error interrupt is generated.<br>1: An error interrupt is generated. |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                  |   |   |   |   |   |   |

## DMAC\_ENBLD\_CHNS

DMAC\_ENBLD\_CHNS is a channel enable register that shows the enabled channels.

If a bit of DMAC\_ENBLD\_CHNS is 1, the corresponding channel is enabled. An enable bit in the DMAC\_CX\_CONFIG register determines whether a corresponding channel is enabled. If the DMA transfer over a channel is complete, the corresponding bit in the DMAC\_ENBLD\_CHNS register is cleared.



| Offset Address |          |                  |    |                 |                                                                            |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |    |    |    |    |                  |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|------------------|----|-----------------|----------------------------------------------------------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|----|----|----|----|------------------|----|---|---|---|---|---|---|---|---|---|---|
| 0x01C          |          |                  |    | DMAC_ENBLD_CHNS |                                                                            |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |    |    |    |    |                  |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30               | 29 | 28              | 27                                                                         | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11               | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                  |    |                 |                                                                            |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    | enabled_channels |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0                | 0  | 0               | 0                                                                          | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0                | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name             |    |                 | Description                                                                |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |                  |    |   |   |   |   |   |   |   |   |   |   |
| [31:4]         | -        | reserved         |    |                 | Reserved                                                                   |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |                  |    |   |   |   |   |   |   |   |   |   |   |
| [3:0]          | RO       | enabled_channels |    |                 | Channel enable. Bit[3:0] map to channels 3–0.<br>0: disabled<br>1: enabled |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |                  |    |   |   |   |   |   |   |   |   |   |   |

DMAC SOFT BREQ

**DMAC\_SOFT\_BREQ** is a burst request register for software. It is used for the software to control whether to generate a DMA burst request.

Reading this register queries the device that is requesting the DMA burst transfer. This register and any peripheral each can generate a DMA request.



## NOTE

You are advised not to use a software DMA request and a hardware DMA request at the same time.

| Offset Address |          |           |    | Register Name  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |           |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|-----------|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x020          |          |           |    | DMAC_SOFT_BREQ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |           |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28             | 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |    |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    | soft_breq |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name      |    |                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved  |    |                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | soft_breq |    |                | <p>Whether to generate DMA burst requests by the software</p> <p>When this register is written:</p> <p>0: no effect</p> <p>1: A DMA burst transfer request is generated. When the transfer is complete, the corresponding bit is cleared.</p> <p>When this register is read:</p> <p>0: The peripheral corresponding to the request signal DMACBREQ[15:0] does not send a DMA burst request.</p> <p>1: The peripheral corresponding to the request signal DMACBREQ[15:0] is requesting a DMA burst transfer.</p> |    |    |    |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## DMAC\_SOFT\_SREQ

**DMAC\_SOFT\_SREQ** is a DMA single request register for software. It is used for the software to control whether to generate a DMA single transfer request.

Reading this register queries the device that is requesting the DMA single transfer. This register and any of the 16 DMA request input signals of the DMAC each can generate a DMA request.

 **NOTE**

You are advised not to use a software DMA request and a hardware DMA request at the same time.

## **DMAC\_SOFT\_LBREQ**

**DMAC\_SOFT\_LBREQ** is a software last burst request register. It is used for the software to control whether to generate a DMA last burst transfer request.



| Offset Address |          |            |    |    |    |                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    | Register Name   |            |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|------------|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|-----------------|------------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x028          |          |            |    |    |    |                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    | DMAC_SOFT_LBREQ |            |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27 | 26                                                                                                                                                                                                           | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    |    |                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |                 | soft_lbreq |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0  | 0                                                                                                                                                                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name       |    |    |    | Description                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved   |    |    |    | Reserved                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | WO       | soft_lbreq |    |    |    | Whether to generate a DMA last burst transfer request by the software<br>0: no effect<br>1: A DMA last burst transfer request is generated. When the transfer is complete, the corresponding bit is cleared. |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DMAC\_SOFT\_LSREQ

DMAC\_SOFT\_LSREQ is a software last single request register. It is used for the software to control whether to generate a DMA last single transfer request.

| Offset Address |          |            |    |    |    |                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    | Register Name   |            |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|------------|----|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|-----------------|------------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x02C          |          |            |    |    |    |                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    | DMAC_SOFT_LSREQ |            |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27 | 26                                                                                                                                                                                                             | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    |    |                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    |                 | soft_lsreq |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0  | 0                                                                                                                                                                                                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name       |    |    |    | Description                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved   |    |    |    | Reserved                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | WO       | soft_lsreq |    |    |    | Whether to generate a DMA last single transfer request by the software<br>0: no effect<br>1: A DMA last single transfer request is generated. When the transfer is complete, the corresponding bit is cleared. |    |    |    |    |    |    |    |    |    |                 |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DMAC\_CONFIG

DMAC\_CONFIG is a configuration register for configuring the DMAC. You can change the endianness mode of the two master interfaces of the DMAC by writing to m1 (bit[1]) and m2 (bit[2]) of this register. After reset, the two master interfaces are set to little endian mode.

### NOTE

The two master interfaces work in little endian mode.



| Offset Address |          |          |    |                                                                            |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |    |    |   |   |   |   |   |   |
|----------------|----------|----------|----|----------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|----|----|---|---|---|---|---|---|
| 0x030          |          |          |    |                                                                            |    |    |    |    |    |    |    |    |    |    |    | DMAC_CONFIG   |    |    |    |    |    |    |   | 0x0000_0000       |    |    |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28                                                                         | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7  | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |                                                                            |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   | m2 | m1 | e |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0                                                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0  | 0  | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name     |    | Description                                                                |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |    |    |   |   |   |   |   |   |
| [31:3]         | -        | reserved |    | Reserved                                                                   |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |    |    |   |   |   |   |   |   |
| [2]            | RW       | m2       |    | Endianness mode of master 2<br>0: little endian mode<br>1: big endian mode |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |    |    |   |   |   |   |   |   |
| [1]            | RW       | m1       |    | Endianness mode of master 1<br>0: little endian mode<br>1: big endian mode |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |    |    |   |   |   |   |   |   |
| [0]            | RW       | e        |    | DMAC enable<br>0: disabled<br>1: enabled                                   |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |    |    |   |   |   |   |   |   |

## DMAC\_SYNC

DMAC\_SYNC is a synchronization register. It is used to enable or disable the synchronization logic provided for DMA request signals.

| Offset Address |          |           |    |                                                                                                        |    |    |    |    |    |    |    |    |    |    |    | Register Name |           |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|--------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|-----------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x034          |          |           |    |                                                                                                        |    |    |    |    |    |    |    |    |    |    |    | DMAC_SYNC     |           |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28                                                                                                     | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |    |                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |               | dmac_sync |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0                                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name      |    | Description                                                                                            |    |    |    |    |    |    |    |    |    |    |    |               |           |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved  |    | Reserved                                                                                               |    |    |    |    |    |    |    |    |    |    |    |               |           |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | dmac_sync |    | Sync logic enable for DMA request signals of the corresponding peripheral<br>0: enabled<br>1: disabled |    |    |    |    |    |    |    |    |    |    |    |               |           |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |



## DMAC\_CX\_SRC\_ADDR

DMAC\_CX\_SRC\_ADDR is a source address register. It shows the source addresses (sorted by byte) of the data to be transmitted.

Its offset address is  $0x100 + X \times 0x20$ .  $X$  ranges from 0 to 3, corresponding to DMA channels 0 to 3.

Before a channel is enabled, its corresponding register must be programmed by software. After the channel is enabled, the register is updated in any of the following cases:

- The source address is incremented.
- A complete data block is transferred and then loaded from LLI nodes.

If a channel is active, no valid information can be obtained when this register is read. This is because that after software obtains the register value, the value has changed during data transfer. Therefore, this register is read after the channel stops data transfer. At this time, the read value is the last source address read by the DMAC.

The source and destination addresses must be aligned with the transfer widths of the source and destination devices.

| Offset Address   |          |          |    |    |                    |    |    |    |    |    |    |    |    |    |    | Register Name    |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |  |
|------------------|----------|----------|----|----|--------------------|----|----|----|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|--|
| 0x100 + X x 0x20 |          |          |    |    |                    |    |    |    |    |    |    |    |    |    |    | DMAC_CX_SRC_ADDR |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |  |
| (X = 0-3)        |          |          |    |    |                    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |
| Bit              | 31       | 30       | 29 | 28 | 27                 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name             | src_addr |          |    |    |                    |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |
| Reset            | 0        | 0        | 0  | 0  | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Bits             | Access   | Name     |    |    | Description        |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |
| [31:0]           | RW       | src_addr |    |    | DMA source address |    |    |    |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |

## DMAC\_CX\_DEST\_ADDR

DMAC\_CX\_DEST\_ADDR is a destination address register. Its offset address is  $0x104+X*0x20$ .  $X$  ranges from 0 to 3, corresponding to DMA channels 0 to 3.

This register contains the destination address (sorted by byte) of the data to be transferred. Before a channel is enabled, its corresponding register must be programmed by software. After the channel is enabled, the register is updated in any of the following cases:

- The destination address is incremented.
- A complete data block is transferred and then loaded from LLI nodes.

If a channel is active, no valid information can be obtained when this register is read. This is because that after software obtains the register value, the value has changed during data transfer. Therefore, this register is read after the channel stops data transfer. At this time, the read value is the last destination address written by the DMAC.



| Offset Address<br>0x104 + X * 0x20<br>(X = 0-3) |           |           |    |                         |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>DMAC_CX_DEST_ADDR |    |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |
|-------------------------------------------------|-----------|-----------|----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------|----|----|----|----|----|----|---|----------------------------------|---|---|---|---|---|---|---|---|
| Bit                                             | 31        | 30        | 29 | 28                      | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                            | dest_addr |           |    |                         |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| Reset                                           | 0         | 0         | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |   |
| Bits                                            | Access    | Name      |    | Description             |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [31:0]                                          | RW        | dest_addr |    | DMA destination address |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |

## DMAC\_CXLLI

DMAC\_CXLLI is an LLI register. Its offset address is  $0x108+X*0x20$ .  $X$  ranges from 0 to 3, corresponding to DMA channels 0 to 3.

The data structure of the DMAC LLI node is as follows:

- [DMAC\\_CX\\_SRC\\_ADDR](#) specifies the start address of the source device
- [DMAC\\_CX\\_DEST\\_ADDR](#) specifies the start address of the destination device.
- [DMAC\\_CX\\_LLNI](#) specifies the address of the next node
- [DMAC\\_CX\\_CONTROL](#) specifies the master, data width, burst size, address increment, and transfer size of the source device and destination device.

**Figure 3-6** Structure of the linked list for the DMAC



### CAUTION

The LLI field value must be less than or equal to 0xFFFF\_FFF0. Otherwise, the address is wrapped around to 0x0000\_0000 during a 4-word burst transfer. As a result, the data structure of LLI nodes cannot be stored in a consecutive address area.

If the LLI field is set to 0, the current node is at the end of the linked list. In this case, the corresponding channel is disabled after data blocks corresponding to the current node are transferred.



| Offset Address<br>0x108+X*0x20<br>(X = 0-3) |        |          |    |                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>DMAC_CXLLI |    |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |          |    |   |   |   |   |   |   |
|---------------------------------------------|--------|----------|----|----------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|----|----|---|----------------------------------|----------|----|---|---|---|---|---|---|
| Bit                                         | 31     | 30       | 29 | 28                                                                                                                               | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7        | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                        | lli    |          |    |                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |    |   |                                  | reserved | lm |   |   |   |   |   |   |
| Reset                                       | 0      | 0        | 0  | 0                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0        | 0  | 0 | 0 | 0 |   |   |   |
| Bits                                        | Access | Name     |    | Description                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |    |   |                                  |          |    |   |   |   |   |   |   |
| [31:2]                                      | RW     | lli      |    | LLI. Bit[31:2] in the next LLI node address and the address bit[1:0] are set to 0. A linked list address must be 4-byte aligned. |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |    |   |                                  |          |    |   |   |   |   |   |   |
| [1]                                         | RW     | reserved |    | Reserved. This bit value must be set to 0 during write operations and masked during read operations.                             |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |    |   |                                  |          |    |   |   |   |   |   |   |
| [0]                                         | RW     | lm       |    | Master for loading the next LLI node<br>0: master 1<br>1: master 2                                                               |    |    |    |    |    |    |    |    |    |    |    |                             |    |    |    |    |    |    |   |                                  |          |    |   |   |   |   |   |   |

## DMAC\_CX\_CONTROL

DMAC\_CX\_CONTROL is a channel control register. Its offset address is 0x10C+I\*0x20. X ranges from 0 to 3, corresponding to DMA channels 0 to 3.

This register contains the control information about the DMA channels, such as the transfer size, burst size, and transfer bit width.

Before a channel is enabled, its corresponding register must be programmed by software. After the channel is enabled, the register is updated when being loaded from a linked list node after a complete data block is transferred.

If a channel is active, no valid information can be obtained when this register is read. This is because after software obtains the register value, the value has changed during data transfer. Therefore, this register is read after the channel stops data transfer.



| Offset Address<br>0x10C+X*0x20<br>(X = 0~3) |        |      |    |                                                                                                                                                                                                                                                                                                                                                        |    |    |        |        |        |        |              | Register Name<br>DMAC_CX_CONTROL |    |    |    |    |    |    |    | Total Reset Value<br>0x0000_0000 |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|---------------------------------------------|--------|------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|--------|--------|--------|--------|--------------|----------------------------------|----|----|----|----|----|----|----|----------------------------------|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| Bit                                         | 31     | 30   | 29 | 28                                                                                                                                                                                                                                                                                                                                                     | 27 | 26 | 25     | 24     | 23     | 22     | 21           | 20                               | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12                               | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Name                                        | i      | prot | di | si                                                                                                                                                                                                                                                                                                                                                     | d  | s  | dwidth | swidth | dbsize | sbsize | transfersize |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| Reset                                       | 0      | 0    | 0  | 0                                                                                                                                                                                                                                                                                                                                                      | 0  | 0  | 0      | 0      | 0      | 0      | 0            | 0                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |  |  |
| Bits                                        | Access | Name |    | Description                                                                                                                                                                                                                                                                                                                                            |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [31]                                        | RW     | i    |    | Transfer completion interrupt enable<br><br>This bit determines whether the current LLI node triggers a transfer completion interrupt.<br>0: disabled<br>1: enabled                                                                                                                                                                                    |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [30:28]                                     | RW     | prot |    | H PROT[2:0] access protection signal transmitted by the master                                                                                                                                                                                                                                                                                         |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [27]                                        | RW     | di   |    | Destination address increment<br><br>0: The destination address is not incremented.<br>1: The destination address is incremented each time a data segment is transferred.<br><br>If the destination device is a peripheral, the destination address is not incremented. If the destination device is a memory, the destination address is incremented. |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [26]                                        | RW     | si   |    | Source address increment<br><br>0: The source address is not incremented.<br>1: The source address is incremented each time a data segment is transferred.<br><br>If the source device is a peripheral, the source address is not incremented. If the source device is a memory, the source address is incremented.                                    |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [25]                                        | RW     | d    |    | Master for accessing the destination device<br><br>0: master 1 for accessing the SPDIF, SIO0, SIO1, UART0, UART1, and SCI<br>1: master 2 for accessing the SPI flash, NAND flash, NOR flash, and DDRC                                                                                                                                                  |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
| [24]                                        | RW     | s    |    | Master for accessing the source device<br><br>0: master 1 for accessing the SPDIF, SIO0, SIO1, UART0, UART1, and SCI<br>1: master 2 for accessing the SPI flash, NAND flash, and DDRC                                                                                                                                                                  |    |    |        |        |        |        |              |                                  |    |    |    |    |    |    |    |                                  |    |    |   |   |   |   |   |   |   |   |   |   |  |  |



|         |    |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------|----|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23:21] | RW | dwidth       | <p>Transfer bit width of the destination device</p> <p>The transfer bit width is invalid if it is greater than the bit width of the master.</p> <p>The data widths of the destination and source devices can be different. The hardware automatically packs and unpacks the data.</p> <p>For details about the mapping between the value of DWidth and the bit width, see <a href="#">Table 3-51</a>.</p>                                                                                                                                                                                                                                        |
| [20:18] | RW | swidth       | <p>Transfer bit width of the source device</p> <p>The transfer bit width is invalid if it is greater than the bit width of the master.</p> <p>The data widths of the destination and source devices can be different. The hardware automatically packs and unpacks the data.</p> <p>For details about the mapping between the value of SWidth and the bit width, see <a href="#">Table 3-51</a>.</p>                                                                                                                                                                                                                                             |
| [17:15] | RW | dbsize       | <p>Burst size of the destination device, indicating the number of data segments to be transferred by the destination device in a burst transfer, that is, the number of transferred data segments when DMACCxBREQ is valid</p> <p>It must be set to a burst size supported by the destination device. If the destination device is a memory, set it to the storage area size beyond the storage address boundary.</p> <p>For details about the mapping between the value of DBSize and the transfer size, see <a href="#">Table 3-50</a>.</p>                                                                                                    |
| [14:12] | RW | sbsize       | <p>Burst size of the source device, indicating the number of data segments to be transferred by the source device in a burst transfer, that is, the number of transferred data segments when DMACCxBREQ is valid</p> <p>It must be set to a burst size supported by the source device. If the source device is a memory, set it to the storage area size beyond the storage address boundary.</p> <p>For details about the mapping between the value of SBSIZE and the transfer size, see table <a href="#">Table 3-51</a>.</p>                                                                                                                  |
| [11:0]  | RW | transfersize | <p>The DMA transfer size can be configured by writing to this register only when the DMAC is a flow controller. This field indicates the amount of data to be transferred by the source device.</p> <p>When this register is read, the amount of data transferred through the bus connected to the destination device is obtained.</p> <p>If a channel is active, no valid information can be obtained when this register is read. This is because that after software obtains the register value, the value has changed during data transfer.</p> <p>Therefore, this register is read after the channel is enabled and data transfer stops.</p> |

[Table 3-50](#) describes the mapping between DBSize or SBSIZE of [DMAC\\_CX\\_CONTROL](#) and the burst lengths.



**Table 3-50** Mapping between the value of DBSize or SBSIZE and the burst size

| DBSize or SBSIZE | Burst Length |
|------------------|--------------|
| 000              | 1            |
| 001              | 4            |
| 010              | 8            |
| 011              | 16           |
| 100              | 32           |
| 101              | 64           |
| 110              | 128          |
| 111              | 256          |

**Table 3-51** describes the mapping between DWidth or SWidth of **DMAC\_CX\_CONTROL** and transfer data width.

**Table 3-51** Mapping between DWidth or SWidth and the transfer bit width

| SWidth or DWidth | Transfer Bit Width  |
|------------------|---------------------|
| 000              | Byte (8 bits)       |
| 001              | Half-word (16 bits) |
| 010              | Word (32 bits)      |
| 011              | Reserved            |
| 100              | Reserved            |
| 101              | Reserved            |
| 110              | Reserved            |
| 111              | Reserved            |

Note the following when configuring **DMAC\_CX\_CONTROL**:

- When the transfer bit width of the source device is smaller than that of the destination device, the product of the transfer bit width and transfer size of the source device must be an integral multiple of the transfer bit width of the destination device. Otherwise, data retention and data loss occur in the FIFO.
- The SWidth and DWidth fields cannot be set to undefined bit widths.
- If the transfer size field is set to 0 and the DMAC is a flow controller, the DMAC does not transfer data. In this case, the programmer needs to disable the DMA channel and reprogram it.
- Do not perform common write/read tests on the **DMAC\_CX\_CONTROL** register, because the transfer size field is different from the common register field whose written value and read value may be the same. During writes, this field serves as a control



register, because it determines the number of data segments to be transferred by the DMAC. During reads, this field serves as a status register, because it returns the number (in the unit of the bit width of the source device) of the remaining data segments to be transferred.

- When the transfer size field is set to a value greater than the depth of the FIFO (peripheral FIFO but not the DMAC FIFO) of the source device or destination device, the mode of DMAC source address or destination address must be set to non-increment mode. Otherwise, the peripheral FIFO may overflow.

The bus access information is provided for the source device or destination device over the master interface signals during data transfer. Such information is related to the bits [DMAC\\_CX\\_CONTROL\[prot\]](#) and [DMAC\\_CX\\_CONTROL\[Lock\]](#) configured by programming channel registers. [Table 3-52](#) describes the three protection bits of the prot field of [DMAC\\_CX\\_CONTROL](#).

**Table 3-52** Definitions of the prot field of [DMAC\\_CX\\_CONTROL](#)

| Bits | Description                 | Purpose                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]  | Cacheable or noncacheable   | Specifies whether the access is cacheable.<br>0: not cacheable<br>1: cacheable<br><br>For example, this bit can notify an advanced microcontroller bus architecture (AMBA) bridge of the following information: When finding the first read operation of the 8-digit burst, this bridge can initiate one 8-digit burst read operation on the destination bus directly instead of transmitting the read operations on the source bus to the destination bus one by one.<br><br>This bit controls the output of the bus signal HPROT[3]. |
| [1]  | Bufferable or nonbufferable | Specifies whether the access is bufferable.<br>0: not bufferable<br>1: bufferable<br><br>For example, this bit can notify an AMBA bridge that the write operation on the source bus can be complete without waiting. That is, the operation can be performed even when the bridge does not arbitrate the operation to the destination bus and the slave device does not receive data completely.<br><br>This bit controls the output of the bus signal HPROT[2].                                                                       |
| [0]  | Privileged or User          | Specifies the access mode.<br>0: user mode<br>1: privileged mode<br><br>This bit controls the output of the bus signal HPROT[1].                                                                                                                                                                                                                                                                                                                                                                                                       |



## DMAC\_CX\_CONFIG

DMAC\_CX\_CONFIG is a channel configuration register. Its offset address is  $0x110 + X \times 0x20$ .  $X$  ranges from 0 to 3, corresponding to DMA channels 0 to 3.

This register is not updated when a new linked list node is loaded.

| Offset Address            |                                                                                                                                                                                                                                                                   | Register Name  |  |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |   | Total Reset Value |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|---|-------------------|---|-----|----|------------|----------|-----------------|----------|----------------|---|--|--|--|--|--|--|--|
| 0x110+X*0x20<br>(X = 0-3) |                                                                                                                                                                                                                                                                   | DMAC_CX_CONFIG |  |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |   | 0x0000_0000       |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| Bit                       | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0                                                                                                                                                               |                |  |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| Name                      | reserved                                                                                                                                                                                                                                                          |                |  |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  | h | a                 | l | itc | ie | flow_cntrl | reserved | dest_peripheral | reserved | src_peripheral | e |  |  |  |  |  |  |  |
| Reset                     | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                |  |                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| Bits                      | Access                                                                                                                                                                                                                                                            | Name           |  | Description                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [31:19]                   | -                                                                                                                                                                                                                                                                 | reserved       |  | Reserved<br>This bit must be set to 0 during write operations and masked during read operations.                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [18]                      | RW                                                                                                                                                                                                                                                                | h              |  | Halt bit<br>0: The DMA request is allowed.<br>1: The subsequent DMA requests are ignored and data in the channel FIFO is completely transmitted.<br>This bit can work with the Active bit and the Channel Enable bit to disable a DMA channel without data loss. |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [17]                      | RO                                                                                                                                                                                                                                                                | a              |  | Active bit<br>0: There is no data in the channel FIFO.<br>1: There is data in the channel FIFO.<br>This bit can work with the Halt bit and the Channel Enable bit to disable a DMA channel without data loss.                                                    |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [16]                      | RW                                                                                                                                                                                                                                                                | l              |  | Lock bit<br>0: Disable lock transfer on the bus.<br>1: Enable lock transfer on the bus.                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [15]                      | RW                                                                                                                                                                                                                                                                | itc            |  | Transfer completion interrupt mask<br>0: masked<br>1: not masked                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |
| [14]                      | RW                                                                                                                                                                                                                                                                | ie             |  | Transfer error interrupt mask<br>0: masked<br>1: not masked                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |   |                   |   |     |    |            |          |                 |          |                |   |  |  |  |  |  |  |  |



|         |    |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:11] | RW | flow_cntrl      | <p>Flow control and transfer type</p> <p>This field specifies the flow controller and transfer type. The flow controller can be the DMAC, source device, or destination device. The transfer type can be memory to peripheral, peripheral to memory, peripheral to peripheral, or memory to memory. For details, see <a href="#">Table 3-53</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [10]    | -  | reserved        | <p>Reserved</p> <p>This bit must be set to 0 during write operations and masked during read operations.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [9:6]   | RW | dest_peripheral | <p>Destination device</p> <p>The field is used to select a peripheral request signal as the request signal for the DMA destination device of the channel.</p> <p>If the destination device for DMA transfer is a memory, this field is ignored.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [5]     | -  | reserved        | <p>Reserved</p> <p>This bit must be set to 0 during write operations and masked during read operations.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4:1]   | RW | src_peripheral  | <p>Source device</p> <p>This field is used to select a peripheral request signal as the request signal for the DMA source device of the channel.</p> <p>If the source device for DMA transfer is a memory, this field is ignored.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]     | RW | e               | <p>Channel enable</p> <p>Reading this field obtains the current channel status.</p> <p>0: disabled</p> <p>1: enabled</p> <p>Clearing this bit can disable a channel. When this bit is cleared, the current bus transfer continues until the data transfer is complete. Then, the channel is disabled and the remaining data in the FIFO is lost. When the last LLI node is transferred or an error occurs during transfer, the channel is also disabled and this bit is cleared. If you want to disable a channel without data loss, the Halt bit must be set to 1 so that the subsequent DMA requests are ignored by the channel. After this, the Active bit must be polled until its value becomes 0, indicating that there is no data in the channel FIFO. At this time, the Enable bit can be cleared.</p> <p>To enable a channel by setting this bit to 1, you must reinitialize the channel. If a channel is enabled by setting this bit to 1 only, an unexpected result may occur.</p> |

When a channel is disabled by writing to the Channel Enable bit, this bit can be set to 1 again only after the corresponding bit of [DMAC\\_ENBLD\\_CHNS](#) is polled to be 0. This is because the channel is not disabled immediately after the Channel Enable bit is cleared. The running delay during a bus burst operation also needs to be considered.



[Table 3-53](#) describes the flow controllers and transfer types corresponding to the flow\_cntrl field of [DMAC\\_CX\\_CONFIG](#).

**Table 3-53** Flow controllers and transfer types corresponding to the flow\_cntrl field

| Bit Value | Transfer Mode                       | Controller         |
|-----------|-------------------------------------|--------------------|
| 000       | Memory to memory                    | DMAC               |
| 001       | Memory to peripheral                | DMAC               |
| 010       | Peripheral to memory                | DMAC               |
| 011       | Source device to destination device | DMAC               |
| 100       | Source device to destination device | Destination device |
| 101       | Memory to peripheral                | Destination device |
| 110       | Peripheral to memory                | Source device      |
| 111       | Source device to destination device | Source device      |



# Contents

---

|                                                       |            |
|-------------------------------------------------------|------------|
| <b>4 Power Management .....</b>                       | <b>4-1</b> |
| 4.1 Overview .....                                    | 4-1        |
| 4.2 Operating Modes .....                             | 4-1        |
| 4.3 Clock Gating and Clock Frequency Adjustment ..... | 4-2        |



# **4 Power Management**

## **4.1 Overview**

Hi3796M V100 provides various low-power control modes to dynamically reduce its power consumption.

- System operating mode control  
In each operating mode except the normal mode, power consumption is reduced to some extent. You can select an operating mode based on the actual power consumption and function requirements.
- Clock gating and clock frequency adjustment  
Unnecessary clocks can be disabled to reduce power consumption. When the function requirements are met, the clock frequency can be adjusted to dynamically reduce power consumption.
- Module low-power control  
When a module is idle, it can be disabled or switched to low-power mode to reduce power consumption.
- DVFS and AVS based on CPU load monitoring

## **4.2 Operating Modes**

The system provides two operating modes:

- Normal mode: operating mode when the system runs normal functional services  
When the system works in normal mode, power consumption can be reduced by using DVFS or AVS or disabling unused clocks.
- Standby mode (light standby mode and passive standby mode)
  - In light standby mode, clocks of most modules such as the CPU and GPU are disabled, and wakeup over the network or USB port is supported.
  - In passive standby mode, the board power supply is turned off. Scheduled wakeup by using the IR or wakeup by pressing a key on the front panel is supported.



## 4.3 Clock Gating and Clock Frequency Adjustment

The system supports clock gating of each module. When a module is idle, its clock can be disabled to reduce power consumption.

The working frequencies of some modules can also be separately adjusted to reduce power consumption. For details about the clock source of each module, see section 3.3 "Clock."



# Contents

|                                    |            |
|------------------------------------|------------|
| <b>5 Memory Interfaces .....</b>   | <b>5-1</b> |
| 5.1 DDRC.....                      | 5-1        |
| 5.1.1 Overview.....                | 5-1        |
| 5.1.2 Features.....                | 5-1        |
| 5.1.3 Function Description.....    | 5-2        |
| 5.2 NANDC .....                    | 5-11       |
| 5.2.1 Overview.....                | 5-11       |
| 5.2.2 Features.....                | 5-11       |
| 5.2.3 Function Description.....    | 5-12       |
| 5.2.4 Data Structure .....         | 5-17       |
| 5.2.5 Software Operations.....     | 5-24       |
| 5.2.6 Others.....                  | 5-26       |
| 5.3 MMC/SD/SDIO Controller.....    | 5-26       |
| 5.3.1 Function Description.....    | 5-27       |
| 5.3.2 Timings and Parameters ..... | 5-34       |
| 5.3.3 Application.....             | 5-35       |



## Figures

|                                                                                                                |      |
|----------------------------------------------------------------------------------------------------------------|------|
| <b>Figure 5-1</b> Connecting the DDRC to two 16-bit DDR3 SDRAMs in 32-bit mode .....                           | 5-3  |
| <b>Figure 5-2</b> Connecting the DDRC to four 8-bit DDR3 SDRAMs in 32-bit mode .....                           | 5-4  |
| <b>Figure 5-3</b> Connecting the DDRC to a 16-bit DDR3 SDRAM in 16-bit mode .....                              | 5-5  |
| <b>Figure 5-4</b> Connecting the DDRC to two 8-bit DDR3 SDRAMs in 16-bit mode .....                            | 5-6  |
| <b>Figure 5-5</b> Block diagram of NANDC interfaces .....                                                      | 5-13 |
| <b>Figure 5-6</b> Typical timing when the NANDC reads a page of data from the NAND flash .....                 | 5-13 |
| <b>Figure 5-7</b> Typical timing when the NANDC programs the NAND flash .....                                  | 5-14 |
| <b>Figure 5-8</b> Data structure of the driver in 8-bit ECC mode (2 KB page size) .....                        | 5-17 |
| <b>Figure 5-9</b> Data structure of data in the NAND flash (with the 2 KB page size) in 8-bit ECC mode .....   | 5-17 |
| <b>Figure 5-10</b> Data structure of the driver in 8-bit ECC mode (4 KB page size) .....                       | 5-17 |
| <b>Figure 5-11</b> Data structure of data in the NAND flash (with the 4 KB page size) in 8-bit ECC mode .....  | 5-18 |
| <b>Figure 5-12</b> Data structure of the driver in 16-bit ECC mode (2 KB page size) .....                      | 5-18 |
| <b>Figure 5-13</b> Data structure of data in the NAND flash (with the 2 KB page size) in 16-bit ECC mode ..... | 5-18 |
| <b>Figure 5-14</b> Data structure of the driver in 16-bit ECC mode (4 KB page size) .....                      | 5-18 |
| <b>Figure 5-15</b> Data structure of data in the NAND flash (with the 4 KB page size) in 16-bit ECC mode ..... | 5-19 |
| <b>Figure 5-16</b> Data structure of the driver in 24-bit ECC mode (2 KB page size) .....                      | 5-19 |
| <b>Figure 5-17</b> Data structure of data in the NAND flash (with the 2 KB page size) in 24-bit ECC mode ..... | 5-19 |
| <b>Figure 5-18</b> Data structure of the driver in 24-bit ECC mode (4 KB page size) .....                      | 5-19 |
| <b>Figure 5-19</b> Data structure of data in the NAND flash (with the 4 KB page size) in 24-bit ECC mode ..... | 5-20 |
| <b>Figure 5-20</b> Data structure of the driver in 24-bit ECC mode (8 KB page size) .....                      | 5-20 |
| <b>Figure 5-21</b> Data structure of data in the NAND flash (with the 8 KB page size) in 24-bit ECC mode ..... | 5-20 |
| <b>Figure 5-22</b> Data structure of the driver in 28-bit ECC mode (2 KB page size) .....                      | 5-20 |
| <b>Figure 5-23</b> Data structure of data in the NAND flash (with the 2 KB page size) in 28-bit ECC mode ..... | 5-21 |
| <b>Figure 5-24</b> Data structure of the driver in 28-bit ECC mode (4 KB page size) .....                      | 5-21 |
| <b>Figure 5-25</b> Data structure of data in the NAND flash (with the 4 KB page size) in 28-bit ECC mode ..... | 5-21 |
| <b>Figure 5-26</b> Data structure of the driver in 28-bit ECC mode (8 KB page size) .....                      | 5-21 |



|                                                                                                                 |      |
|-----------------------------------------------------------------------------------------------------------------|------|
| <b>Figure 5-27</b> Data structure of data in the NAND flash (with the 8 KB page size) in 28-bit ECC mode .....  | 5-22 |
| <b>Figure 5-28</b> Data structure of the driver in 40-bit ECC mode (8 KB page size) .....                       | 5-22 |
| <b>Figure 5-29</b> Data structure of data in the NAND flash (with the 8 KB page size) in 40-bit ECC mode .....  | 5-22 |
| <b>Figure 5-30</b> Data structure of the driver in 40-bit ECC mode (16 KB page size) .....                      | 5-22 |
| <b>Figure 5-31</b> Data structure of data in the NAND flash (with the 16 KB page size) in 40-bit ECC mode ..... | 5-23 |
| <b>Figure 5-32</b> Data structure of the driver in 64-bit ECC mode (8 KB page size) .....                       | 5-23 |
| <b>Figure 5-33</b> Data structure of data in the NAND flash (with the 8 KB page size) in 64-bit ECC mode .....  | 5-23 |
| <b>Figure 5-34</b> Data structure of the driver in 64-bit ECC mode (16 KB page size) .....                      | 5-24 |
| <b>Figure 5-35</b> Data structure of data in the NAND flash (with the 16 KB page size) in 64-bit ECC mode ..... | 5-24 |
| <b>Figure 5-36</b> Functional block diagram of the MMC controller .....                                         | 5-27 |
| <b>Figure 5-37</b> Typical application circuit of the MMC controller .....                                      | 5-28 |
| <b>Figure 5-38</b> Format of an MMC command .....                                                               | 5-29 |
| <b>Figure 5-39</b> Format of the response to an MMC command .....                                               | 5-30 |
| <b>Figure 5-40</b> Running an MMC non-data transfer command .....                                               | 5-30 |
| <b>Figure 5-41</b> Single-block and multi-block read operations .....                                           | 5-32 |
| <b>Figure 5-42</b> Single-block and multi-block write operations .....                                          | 5-32 |
| <b>Figure 5-43</b> Data transfer format in 1-bit mode .....                                                     | 5-33 |
| <b>Figure 5-44</b> Data transfer format in 4-bit mode .....                                                     | 5-33 |
| <b>Figure 5-45</b> Output timing .....                                                                          | 5-35 |
| <b>Figure 5-46</b> Input timing .....                                                                           | 5-35 |
| <b>Figure 5-47</b> Structure of the dual-buffer descriptor .....                                                | 5-42 |
| <b>Figure 5-48</b> Structure of the linked descriptor .....                                                     | 5-43 |
| <b>Figure 5-49</b> Internal structure of 32-bit descriptors .....                                               | 5-43 |



# Tables

|                                                                                                                          |      |
|--------------------------------------------------------------------------------------------------------------------------|------|
| <b>Table 5-1</b> DDR3 SDRAMs supported by the DDRC .....                                                                 | 5-2  |
| <b>Table 5-2</b> Command truth table of the DDRC .....                                                                   | 5-7  |
| <b>Table 5-3</b> Address mapping when the DDRC is in 32-bit mode.....                                                    | 5-10 |
| <b>Table 5-4</b> Address mapping when the DDRC is in 16-bit mode.....                                                    | 5-10 |
| <b>Table 5-5</b> K9F2G08U0M addresses .....                                                                              | 5-16 |
| <b>Table 5-6</b> K9GAG08X0M addresses .....                                                                              | 5-16 |
| <b>Table 5-7</b> Common commands for operating the NAND flash .....                                                      | 5-16 |
| <b>Table 5-8</b> Load parameters of signal lines .....                                                                   | 5-28 |
| <b>Table 5-9</b> Mapping between transmission modes and voltages .....                                                   | 5-34 |
| <b>Table 5-10</b> Timing parameters of the MMC interface .....                                                           | 5-34 |
| <b>Table 5-11</b> Reference/Default values of MMC_CMD when a non-data transfer command is executed .....                 | 5-38 |
| <b>Table 5-12</b> Reference/Default values of MMC_CMD when a single data block or multiple data blocks are read .....    | 5-40 |
| <b>Table 5-13</b> Reference/Default values of MMC_CMD when a single data block or multiple data blocks are written ..... | 5-41 |
| <b>Table 5-14</b> Definition of each bit of DES0 .....                                                                   | 5-43 |
| <b>Table 5-15</b> Definition of each bit of DES1 .....                                                                   | 5-44 |
| <b>Table 5-16</b> Definition of each bit of DES2 .....                                                                   | 5-45 |
| <b>Table 5-17</b> Definition of each bit of DES3 .....                                                                   | 5-45 |
| <b>Table 5-18</b> Reference configuration of MMC_CMDARG when the resume operation is performed .....                     | 5-48 |



# 5 Memory Interfaces

## 5.1 DDRC

### 5.1.1 Overview

The DDR3 SDRAM controller (DDRC) controls access to the DDR3 SDRAM.

### 5.1.2 Features

The DDRC has the following features:

- One DDR3 SDRAM chip select (CS)
- Configurable DDR3 SDRAM data bus bit width (32 bits or 16 bits). When the 32-bit mode is used, the capacity of the upper 16-bit DDR3 SDRAM is the same as that of the lower 16-bit DDR3 SDRAM.
- Maximum 2 GB storage capacity
- Maximum 800 MHz DDR3 SDRAM working frequency and 1600 Mbit/s data rate
- Various DDR3 SDRAM low-power modes, such as the power-down and self-refresh modes
- Burst8 transfer mode for the DDR3 SDRAM



## 5.1.3 Function Description

### 5.1.3.1 Application Block Diagram

The DDRC enables the master devices of the SoC such as the CPU to access the external DDR3 SDRAM. It supports the DDR3 SDRAM that complies with the JEDEC (JESD79) standard after the timing parameter registers of the DDRC are configured by using the CPU. [Table 5-1](#) lists the mainstream DDR3 SDRAMs supported by the DDRC. The descriptions in [Table 5-1](#) are based on the working frequencies of DDR3 SDRAMs. The restrictions such as the capacity are not taken into consideration.

**Table 5-1** DDR3 SDRAMs supported by the DDRC

| Vendor                    | 400 MHz                                         | 533 MHz                             | 667 MHz                | 800 MHz   | Remarks |
|---------------------------|-------------------------------------------------|-------------------------------------|------------------------|-----------|---------|
| JESD79<br>(DDR3 standard) | DDR3-800<br>DDR3-1066<br>DDR3-1333<br>DDR3-1600 | DDR3-1066<br>DDR3-1333<br>DDR3-1600 | DDR3-1333<br>DDR3-1600 | DDR3-1600 | 1, 2    |

#### NOTE

The maximum working frequency of the DDR3 SDRAM supported by the DDRC is 800 MHz.

For details about the supported component types, see the JEDEC standard and the component data sheet.

The DDRC supports the 32-bit or 16-bit DDR. In 32-bit mode, the DDRC connects to two 16-bit DDR3 SDRAMs or four 8-bit DDR3 SDRAMs; in 16-bit mode, the DDRC connects to one 16-bit DDR3 SDRAM or two 8-bit DDR3 SDRAMs.

[Figure 5-1](#) and [Figure 5-2](#) show the connection between the DDRC and DDR3 SDRAMs in 32-bit mode.



**Figure 5-1** Connecting the DDRC to two 16-bit DDR3 SDRAMs in 32-bit mode



The DDR3 SDRAM is a 16-bit memory.

The DDRC command control

signals DDR\_CS, DDR\_CKE, DDR\_RESET\_N, DDR\_RAS\_N, DDR\_CAS\_N, DDR\_WE\_N, DDR\_BA[2:0], DDR\_A[14:0], and DDR\_ODT connect to the command control signals of DDR3 SDRAMx.

**Figure 5-2** Connecting the DDRC to four 8-bit DDR3 SDRAMs in 32-bit mode

The DDR3 SDRAMx is an 8-bit memory.



The DDRC command control signals DDR\_CS, DDR\_CKE, DDR\_RESET\_N, DDR\_RAS\_N, DDR\_CAS\_N, DDR\_WE\_N, DDR\_BA[2:0], and DDR\_A[14:0] connect to the command control signals of DDR3 SDRAMx.

[Figure 5-3](#) and [Figure 5-4](#) show the connection between the DDRC and DDR3 SDRAMs in 16-bit mode.

**Figure 5-3** Connecting the DDRC to a 16-bit DDR3 SDRAM in 16-bit mode



The DDR3 SDRAM is a 16-bit memory.

The DDRC command control signals DDR\_CS, DDR\_CKE, DDR\_RESET\_N, DDR\_RAS\_N, DDR\_CAS\_N, DDR\_WE\_N, DDR\_BA[2:0], DDR\_A[14:0], and DDR\_ODT connect to the command control signals of the DDR3 SDRAM.



Figure 5-4 Connecting the DDRC to two 8-bit DDR3 SDRAMs in 16-bit mode



The DDR3 SDRAMx is an 8-bit memory.

The DDRC command control signals DDR\_CS, DDR\_CKE, DDR\_RESET\_N, DDR\_RAS\_N, DDR\_CAS\_N, DDR\_WE\_N, DDR\_BA[2:0], and DDR\_A[14:0] connect to the command control signals of DDR3 SDRAMx.

### 5.1.3.2 Function Implementation

As the timings of the DDRC interface comply with the JESD79 standard, the DDRC can access the data of the DDR3 SDRAM and control the status of the DDR3 SDRAM by sending the command words of the DDR3 SDRAM. For example, the DDRC can read and write to the DDR3 SDRAM, automatically refresh the DDR3 SDRAM, and control the power consumption of the DDR3 SDRAM.

### Command Truth Table

The DDRC supports the read, write, and control command words of the DDR3 SDRAM. [Table 5-2](#) lists the command truth values of the DDRC. For details, see the JEDEC standard and component data sheet.

**Table 5-2** Command truth table of the DDRC

| Function           | DDR3_CKE | DDR3_CSN | DDR3_RAS_N | DDR3_CAS_N | DDR3_WEN | DDR3_ADDR |        |     | DDR3_BA |
|--------------------|----------|----------|------------|------------|----------|-----------|--------|-----|---------|
|                    |          |          |            |            |          | 15:11     | AP(10) | 9:0 |         |
| Deselect           | H        | H        | X          | X          | X        | X         | X      | X   | X       |
| Active             | H        | L        | L          | H          | H        | V         | V      | V   | V       |
| Read               | H        | L        | H          | L          | H        | V         | V      | V   | V       |
| Write              | H        | L        | H          | L          | L        | V         | V      | V   | V       |
| Precharge          | H        | L        | L          | H          | L        | V         | L      | V   | BA      |
| Precharge all      | H        | L        | L          | H          | L        | V         | H      | V   | V       |
| Auto refresh       | H        | L        | L          | L          | H        | V         | V      | V   | V       |
| Self refresh entry | H->L     | L        | L          | L          | H        | V         | V      | V   | V       |
| Self refresh exit  | L->H     | L        | H          | H          | H        | V         | V      | V   | V       |
| Mode register set  | H        | L        | L          | L          | L        | V         | V      | V   | V       |
| ZQCL               | H        | L        | H          | H          | L        | X         | H      | X   | X       |
| ZQCS               | H        | L        | H          | H          | L        | X         | L      | X   | X       |

H: high level; L: low level; V: valid; X: ignored.

ZQ calibration long (ZQCL): starts ZQ calibration on the DDR3 SDRAM when it is initialized during power-on.

ZQ calibration short (ZQCS): starts a calibration on the DDR3 SDRAM when its ambient environment is changed.

## Auto Refresh

When DDRC\_CFG\_TIMING2 [taref] is set to a non-zero value, the DDRC refreshes the DDR3 SDRAM by automatically generating a periodical auto refresh command. At ambient temperature, the DDR3 SDRAM is required to implement 8,192 auto-refresh operations within 64 ms. That is, the auto-refresh cycle is 7.8  $\mu$ s. The relationship between the value of DDRC\_CFG\_TIMING2 [taref] (taref) and the auto-refresh cycle T (T = 7.8  $\mu$ s) is as follows:

$$T \geq taref \times (16 \times \text{DDR clock cycle})$$

When DDRC\_CFG\_TIMING2 [taref] is configured, the internal counter of the DDRC automatically loads the taref value and then counts in decremental mode. When the count value reaches 0, the DDRC initiates an auto-refresh operation and the counter reloads the taref value to count.



## Low-Power Management

The DDRC supports two modes of low-power management: common low-power mode and auto-refresh low-power mode.

When DDRC\_CFG\_PD [pd\_en] is set to 1 to enable the SDRAM low-power mode, and the system is idle (the DDR is not read or written through the DDRC bus interface for a period), the DDR3 SDRAM enters the common low-power mode automatically.

When the system needs to enter standby mode, you can force the DDR3 SDRAM to enter the auto-refresh mode by setting DDRC\_CTRL\_SREF [sref\_req] to 1. In this mode, the power consumption of the DDR3 SDRAM is minimized, data in the DDR3 SDRAM is retained, but the system cannot access the DDR3 SDRAM.

## Arbitration Mechanism

The DDRC implements the priority scheduling algorithm and traffic control algorithm.

The priority mapping mode can be selected by configuring AXI\_QOSCFG0n[id\_map\_mode]. Currently AXI\_QOSCFG0n[id\_map\_mode] must be set to 1, that is, the system bus signal is used as the QoS priority. The DDRC adds priority attributes to the read/write commands sent to the bus by configuring AXI\_WPRPRI and AXI\_RDPRI, and then schedules the commands based on the priority attributes. In this way, the DDR3 SDRAM is accessed in a highly efficient manner.

The DDRC can also add the response delay attribute (timeout) to the commands sent to the bus by setting AXI\_WRTOUT and AXI\_RDTOUT to non-zero values. The mapping mode of the timeout period can be selected by configuring AXI\_QOSCFG0n[tout\_map\_mode]. Currently AXI\_QOSCFG0n[tout\_map\_mode] must be set to 1, that is, the 2-bit select signal of the system bus is used as the address to search for one of the four preset timeout periods. Then the bus command response timeout is ensured based on the response timeout priority scheduling algorithm.

By configuring DDRC\_CFG\_PERF[flux\_en] and AXI\_FLUX0n[flux\_cfg0], the DDRC adds the traffic control attributes to bus interfaces and allocates traffic to each bus interface to ensure sufficient bandwidth of each interface when the traffic is heavy. The commands with the response timeout attributes are not restricted under traffic control after the timeout period elapses.

## Traffic Statistics and Command Latency Statistics

The DDRC supports traffic statistics of the read/write operation based on an ID and the overall read and write traffic statistics. The DDRC can also collect statistics on the DDR interface usage. The statistic counter supports the consecutive count mode and one-shot count mode. In consecutive count mode, the counter is a non-saturation counter, and it is wrapped when the maximum count is reached. Therefore, the system needs to read the count value before the counter is wrapped. In one-shot count mode, the counter stops counting when the statistic time elapses. The system can obtain the instantaneous traffic and latency by using this function.

The DDRC supports command latency statistics, including the accumulative latency statistics.

The process for collecting statistics is as follows:

- Step 1** Set the statistic mode to consecutive triggering or one-shot triggering by configuring DDRC\_CFG\_PERF[perf\_mode]. If one-shot triggering is selected, set the perf\_prd field to configure the statistic cycle.



- Step 2** Set the ID for which statistics are to be collected by configuring DDRC\_CFG\_STAID.
- Step 3** Set the mask value of the ID by configuring DDRC\_CFG\_STAIDMSK. The DDRC determines whether to collect statistics on the current access based on sta\_idmask and the accessed ID. Statistics of multiple IDs can be collected by using this method.
- Step 4** Enable statistics by configuring DDRC\_CTRL\_PERF[perf\_en]. For the one-shot counting, counting is complete when DDRC\_CTRL\_PERF[perf\_en] is restored to 0. For the consecutive counting, software needs to write 0 to DDRC\_CTRL\_PERF[perf\_en] to stop counting.
- Step 5** Observe the statistics by using DDRC\_HIS\_FLUX\_WR, DDRC\_HIS\_FLUX\_RD, DDRC\_HIS\_FLUX\_WCMD, DDR\_C\_HIS\_FLUX\_RCMD, DDRC\_HIS\_FLUXID\_WR, DDRC\_HIS\_FLUXID\_RD, DDRC\_HI\_S\_FLUXID\_WCMD, DDRC\_HIS\_FLUXID\_RCMD, DDRC\_HIS\_WLATCNT0, DDRC\_HI\_S\_WLATCNT1, DDRC\_HIS\_RLATCNT0, DDRC\_HIS\_RLATCNT1, and DDRC\_HIS\_INHERE\_RLAT\_CNT.

----End

## Address Mapping Mode

The DDRC can convert the access address for the system bus into that for the DDR3 SDRAM. Set the address mapping mode to row-bank-column (RBC) by configuring DDRC\_CFG\_RNKVOL0 [mem\_map]. Currently, only the RBC mode is supported. Then set the SDRAM row and column address bit widths by configuring DDRC\_CFG\_RNKVOL0[mem\_row] and DDRC\_CFG\_RNKVOL0[mem\_col] respectively. The DDRC then converts the system bus address into the DDR3 SDRAM address based on the address mapping algorithm.

The following describes the mapping algorithms for the system bus address and DDR3 SDRAM address by using the RBC mode as an example. Assume that the system bus address is BUSADR[31:0], the valid address is BUSADR[m – 1:0], and the address for the DDR3 SDRAM is DDRADDR[14:0]. When DDRADDR[14:0] serves as the row address, its valid address is DDRROW[x – 1:0]; when DDRADDR[13:0] serves as the column address, its valid address is DDCOL[y – 1:0]. In addition, the bank address for the DDR is DDRBA[z – 1:0] and the width of the storage data bus of the DDRC is DW. In this case, the address mappings are as follows:

- When DDRC\_CFG\_RNKVOL0[mem\_map] is set to 2'b00, the RBC mapping mode is as follows:  
$$\text{BUSADR}[m - 1:0] = \{\text{DDRROW}[x - 1:0], \text{DDRBA}[z - 1:0], \text{DDCOL}[y - 1:0], \text{DW}\{b0\}\}$$
In the preceding expression, the following condition is met:  $m = x + y + z + DW$ 
  - When the DDRC is in 32-bit mode, the value of DW is 2.
  - When the DDRC is in 16-bit mode, the value of DW is 1.
- When DDRC\_CFG\_RNKVOL0[mem\_map] is set to 2'b00 and A10 acts as the AP function bit of the DDR, the mapping between the system bus addresses and the DDR3 SDRAM addresses is described as follows.

Table 5-3 and Table 5-4 describe the address mappings in RBC mode.



**Table 5-3** Address mapping when the DDRC is in 32-bit mode

| Memory Type   | Row Address Width | Column Address Width | DDR BA |    |    | Row/Column Address | DDR ADR |    |    |    |    |        |    |    |       |
|---------------|-------------------|----------------------|--------|----|----|--------------------|---------|----|----|----|----|--------|----|----|-------|
|               |                   |                      | 2      | 1  | 0  |                    | 15      | 14 | 13 | 12 | 11 | 10/A P | 9  | 8  | 7:0   |
| 1 Gbit 8 bank |                   |                      |        |    |    |                    |         |    |    |    |    |        |    |    |       |
| 64 x 16       | 13                | 9                    | 14     | 13 | 12 | Row address        | -       | -  | -  | 27 | 26 | 25     | 24 | 23 | 22:15 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | -  | -  | AP     | 11 | 10 | 9:2   |
| 2 Gbit 8 bank |                   |                      |        |    |    |                    |         |    |    |    |    |        |    |    |       |
| 128 x 16      | 14                | 9                    | 14     | 13 | 12 | Row address        | -       | -  | 28 | 27 | 26 | 25     | 24 | 23 | 22:15 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | -  | -  | AP     | 11 | 10 | 9:2   |
| 4Gbit 8bank   |                   |                      |        |    |    |                    |         |    |    |    |    |        |    |    |       |
| 256 x 16      | 15                | 10                   | 13     | 12 | 11 | Row address        | -       | 29 | 28 | 27 | 26 | 25     | 24 | 23 | 22:15 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | -  | -  | AP     | 11 | 10 | 9:2   |
| 8 Gbit 8 bank |                   |                      |        |    |    |                    |         |    |    |    |    |        |    |    |       |
| 512 x 16      | 16                | 10                   | 13     | 12 | 11 | Row address        | 30      | 29 | 28 | 27 | 26 | 25     | 24 | 23 | 22:15 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | -  | -  | AP     | 11 | 10 | 9:2   |

**Table 5-4** Address mapping when the DDRC is in 16-bit mode

| Memory Type     | Row Address Width | Column Address Width | DDR BA |    |    | Row/Column Address | DDR ADR |    |    |        |    |    |       |  |  |
|-----------------|-------------------|----------------------|--------|----|----|--------------------|---------|----|----|--------|----|----|-------|--|--|
|                 |                   |                      | 2      | 1  | 0  |                    | 13      | 12 | 11 | 10/A P | 9  | 8  | 7:0   |  |  |
| 256 Mbit 4 bank |                   |                      |        |    |    |                    |         |    |    |        |    |    |       |  |  |
| 16 x 16         | 13                | 9                    | -      | 11 | 10 | Row address        | -       | 24 | 23 | 22     | 21 | 20 | 19:12 |  |  |
|                 |                   |                      |        |    |    | Column address     | -       | -  | -  | AP     | -  | 9  | 8:1   |  |  |
| 512 Mbit 4 bank |                   |                      |        |    |    |                    |         |    |    |        |    |    |       |  |  |



| Memory Type   | Row Address Width | Column Address Width | DDR BA |    |    | Row/Column Address | DDR ADR |    |    |        |    |    |       |
|---------------|-------------------|----------------------|--------|----|----|--------------------|---------|----|----|--------|----|----|-------|
|               |                   |                      | 2      | 1  | 0  |                    | 13      | 12 | 11 | 10/A P | 9  | 8  | 7:0   |
| 32 x 16       | 13                | 10                   | -      | 12 | 11 | Row address        | -       | 25 | 24 | 23     | 22 | 21 | 20:13 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | AP     | 10 | 9  | 8:1   |
| 1 Gbit 8 bank |                   |                      |        |    |    |                    |         |    |    |        |    |    |       |
| 64 x 16       | 13                | 10                   | 13     | 12 | 11 | Row address        |         | 26 | 25 | 24     | 23 | 22 | 21:14 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | AP     | 10 | 9  | 8:1   |
| 2 Gbit 8 bank |                   |                      |        |    |    |                    |         |    |    |        |    |    |       |
| 128 x 16      | 14                | 10                   | 13     | 12 | 11 | Row address        | 27      | 26 | 25 | 24     | 23 | 22 | 21:14 |
|               |                   |                      |        |    |    | Column address     | -       | -  | -  | AP     | 10 | 9  | 8:1   |

## 5.2 NANDC

### 5.2.1 Overview

The NAND flash controller (NANDC) provides memory controller interfaces for connecting to external NAND flash memories to access data.

### 5.2.2 Features

The NANDC has the following features:

- Provides 9 KB (8192 bytes+1024 bytes) on-chip buffer for improving the read speed.
- Supports one CSs, one independent read\_busy signals.
- Supports the CS don't care mode for reducing power consumption of the NAND flash.
- Supports bad block skipping and a maximum of 1 MB boot space.
- Supports boot without pin configuration. The component configuration information is automatically detected and adapted, including the page size, block size, and required error correcting code (ECC) capability.
- Supports the low-power mode.
- Supports NAND flash interfaces with 8-bit data bus.
- Allows the chip to boot from the NAND flash (with the page size of 2 KB, 4 KB, 8 KB, or 16 KB) corresponding to CS0.



- Enables or disables ECC check and error correction.
  - 8 bits/1 KB, 16 bits/1 KB, 24 bits/1 KB BCH, and 28 bits/1 KB BCH code ECC check and error correction for the NAND flash with the 2 KB page size
  - 8 bits/1 KB, 16 bits/1 KB, 24 bits/1 KB, and 28 bits/1 KB BCH code ECC check and error correction for the NAND flash with the 4 KB page size
  - 24 bits/1 KB, 28 bits/1 KB, 40 bits/1 KB, and 64 bits/1 KB BCH code ECC check and error correction for the NAND flash with the 8 KB page size
  - 40 bits/1 KB and 64 bits/1 KB BCH code ECC check and error correction for the NAND flash with the 16 KB page size
- Reports the read/write interrupt, erase interrupt, programming completion interrupt, and ECC check error interrupt.
- Supports read and write operations on data with variable length in ECC0 mode; write operations on the entire page in non-ECC0 mode; and direct memory access (DMA) read operations on only the out-of-band (OOB) or the entire page in non-ECC0 mode
- Flexibly configures the commands and addresses issued by the controller to support various NAND flash command operations (including cache read and write)
- Provides write protection for the NAND flash and allows write-protected addresses to be configured.
- Supports the lock and lock-down modes and allows the flash lock and flash global lock to be enabled and disabled. By default, the flash lock and flash global lock are disabled.
- Allows the randomizer function to be enabled for the NAND flash with the 8 KB or 16 KB page size.

## 5.2.3 Function Description

### 5.2.3.1 Block Diagram

Hi3796M V100 provides one CS and one ready/busy signal. [Figure 5-5](#) shows the block diagram of NANDC interfaces.

**Figure 5-5** Block diagram of NANDC interfaces

### 5.2.3.2 Function Implementation

The data storage structure of the NAND flash consists of blocks and pages. Each block contains several pages. Before writing data to the NAND flash, you must erase the NAND flash by block, and then read/write to the NAND flash by page.

The commands for operating the NAND flash vary according to vendors. For details, see the appropriate NAND flash manual.

**Figure 5-6** shows the typical timing when the NANDC reads a page of data from the NAND flash.

**Figure 5-6** Typical timing when the NANDC reads a page of data from the NAND flash

A typical read operation is performed as follows:

- Step 1** Send the read command 0x00 to the NAND flash.
- Step 2** Send the read start address. The start address consists of the page internal address, page address, and block address. For details, see the appropriate NAND flash manual.
- Step 3** Send the read confirmation command 0x30. The NAND flash pulls the RB signal low, indicating that the NAND flash is being read. About 25  $\mu$ s later, the RB signal becomes high, indicating that data of the NAND flash has been prepared.
- Step 4** Output the NF\_RD\_N signal, and sample the NAND flash data at the rising edge of the NF\_RD\_N signal.

----End

[Figure 5-7](#) shows the typical timing when the NANDC programs the NAND flash.

**Figure 5-7** Typical timing when the NANDC programs the NAND flash



A typical program (write) operation is performed as follows:

- Step 1** Send the programming command 0x80 to the NAND flash.
- Step 2** Send the start address from which data is written. The start address consists of the page internal address, page address, and block address. For details, see the appropriate NAND flash manuals.
- Step 3** Write data to the internal buffer of the NAND flash.
- Step 4** Send the program confirmation command 0x10. The NAND flash pulls the RB signal low, indicating that the NAND flash is being programmed. About 200 ms later, the RB signal becomes high, indicating that the program operation is complete.
- Step 5** Send the command 0x70 to read the NAND flash status to check whether the program operation is successful.

----End



### 5.2.3.3 Operating Mode

#### Boot Mode

- The NANDC is in boot mode by default. The system can boot from only the NAND flash corresponding to CS0, even when the randomizer is enabled.
- The CPU can directly read data stored in a 1 MB address space in boot mode.
- When the system boots from the NAND flash, the NANDC automatically sends a command to read the corresponding page of the NAND flash based on the address read by the CPU and then returns the corresponding data.
- The CPU cannot write to the internal buffer.
- Bad blocks can be automatically identified and skipped. If seven consecutive bad blocks are detected, the boot fails.
- The boot configuration pins must be configured properly based on the models of the connected NAND flash.
- The boot mode can be automatically configured based on the component type.
- When the boot mode is automatically configured based on the component type, the following specifications are supported:
  - 8-bit ECC (2 KB/4 KB page size)
  - 24-bit ECC (2 KB/4 KB/8 KB page size)
  - 40-bit ECC (8 KB/16 KB page size)
  - 60-bit ECC (8 KB/16 KB page size).

The randomizer can be enabled or disabled in 24-bit and 40-bit ECC modes (8 KB page size). The randomizer is disabled when the page size is 2 KB or 4 KB but enabled in other modes by default. The block size can be automatically configured to 64 pages, 128 pages, 256 pages, and 512 pages.

#### Normal Mode

The NANDC can be switched to the normal mode by setting NFC\_CON[op\_mode] to 1. In this mode, the CPU can erase, program, and read the NAND flash.

#### NAND Flash Addresses

The NANDC does not translate addresses. It sends the values of low-bit and upper-bit address registers to the NAND flash directly based on the number of addresses configured by the command configuration register. Therefore, the software needs to translate the address for the CPU into the address for the NAND flash and then write the translated address to the address register. For details about the address configuration requirements for each flash memory, see the user manual of the corresponding NAND flash.

**Table 5-5** lists the requirements for setting the addresses for the Samsung K9F2G08U0M memory. Its capacity is 256 MB x 8 bits and its page size is 2 KB. A0 to A11 indicate the page internal addresses (column addresses), and A12 to A27 indicate the page addresses (row addresses).



**Table 5-5** K9F2G08U0M addresses

| Cycle     | IO0 | IO1 | IO2 | IO3 | IO4 | IO5 | IO6 | IO7 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|
| 1st cycle | A0  | A1  | A2  | A3  | A4  | A5  | A6  | A7  |
| 2nd cycle | A8  | A9  | A10 | A11 | 0   | 0   | 0   | 0   |
| 3rd cycle | A12 | A13 | A14 | A15 | A16 | A17 | A18 | A19 |
| 4th cycle | A20 | A21 | A22 | A23 | A24 | A25 | A26 | A27 |

**Table 5-6** lists the requirements for setting the addresses for the Samsung K9GAG08X0M memory. Its capacity is 2 GB x 8 bits and its page size is 4 KB. A0 to A12 indicate the page internal addresses (column addresses), and A13 to A31 indicate the page addresses (row addresses).

**Table 5-6** K9GAG08X0M addresses

| Cycle     | IO0 | IO1 | IO2 | IO3 | IO4 | IO5 | IO6 | IO7 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|
| 1st cycle | A0  | A1  | A2  | A3  | A4  | A5  | A6  | A7  |
| 2nd cycle | A8  | A9  | A10 | A11 | A12 | 0   | 0   | 0   |
| 3rd cycle | A13 | A14 | A15 | A16 | A17 | A18 | A19 | A20 |
| 4th cycle | A21 | A22 | A23 | A24 | A25 | A26 | A27 | A28 |
| 5th cycle | A29 | A30 | A31 | 0   | 0   | 0   | 0   | 0   |

## Operation Commands

The NAND flash vendors may provide certain advanced commands. **Table 5-7** lists the common commands for operating the NAND flash.

**Table 5-7** Common commands for operating the NAND flash

| Operation   | 1 <sup>st</sup> cycle | 2 <sup>nd</sup> cycle | Remarks |
|-------------|-----------------------|-----------------------|---------|
| READ        | 00H                   | 30H                   | -       |
| PROGRAM     | 80H                   | 10H                   | -       |
| BLOCK ERASE | 60H                   | D0H                   | -       |
| READ ID     | 90H                   | -                     | -       |
| READ STATUS | 70H                   | -                     | -       |
| RESET       | FFH                   | -                     | -       |



## 5.2.4 Data Structure

The size of the NANDC internal buffer is  $(8192 + 1024)$  bytes. This section describes the storage structures of the data read from or written to the NAND flash in the NANDC buffer.

### 5.2.4.1 Non-ECC Mode

When no ECC check is required for the NAND flash:

- During write operations, the NANDC transparently writes the data in buffers to the NAND flash without processing.
- During read operations, the NANDC writes data read from the NAND flash to the internal buffers without processing.
- The number of bytes of the read or written data is specified by the NFC\_DATA\_NUM register. The NAND flash with the 2 KB, 4 KB, 8 KB, or 16 KB page size is supported.
- The non-ECC mode is used when the read ID, set feature, and get feature operations are performed.

### 5.2.4.2 8-Bit/1024-Byte ECC Mode

#### 2KB Page Size

[Figure 5-8](#) shows the data structure of the driver in 8-bit ECC mode (2 KB page size).

**Figure 5-8** Data structure of the driver in 8-bit ECC mode (2 KB page size)



BB: bad block, 2 bytes

CTRL: control area for software, 30 bytes

The storage structure of the data in NANDC buffers is the same as that in the driver.

[Figure 5-9](#) shows the data structure of the data written to the NAND flash. The 2080-byte valid data of the software is divided into two 1040-byte data segments, and the 14-byte ECC is calculated for each data segment. Then the data segments and ECC code are written to the NAND flash alternately. Data structure of data in the NAND flash (with the 4 KB page size) in 8-bit ECC mode

**Figure 5-9** Data structure of data in the NAND flash (with the 2 KB page size) in 8-bit ECC mode



#### 4 KB Page Size

[Figure 5-10](#) shows the data structure of the driver in 8-bit ECC mode (4 KB page size).

**Figure 5-10** Data structure of the driver in 8-bit ECC mode (4 KB page size)





BB: bad block, 2 bytes  
CTRL: control area for software, 30 bytes

**Figure 5-11** shows the data structure of the data written to the NAND flash. The software valid data is divided into four 1032-byte data segments, and the ECC is calculated for each data segment.

Data written to the NAND flash is automatically stored in three segments in the alternate form of 1032-byte data+14-byte ECC code. For the last data segment (1032-byte data+14-byte ECC code), the bad block flag is inserted in byte 4096 of the NAND flash.

**Figure 5-11** Data structure of data in the NAND flash (with the 4 KB page size) in 8-bit ECC mode

DATA(1032)+ECC(14)+DATA(1032)+ECC(14)+DATA(1032)+ECC(14)+DATA(958)+BB(2) +DATA(42)+ECC(14)+CTRL(30)

### 5.2.4.3 16-Bit/1024-Byte ECC Mode

#### 2 KB Page Size

**Figure 5-12** shows the data structure of the driver in 16-bit ECC mode (2 KB page size).

**Figure 5-12** Data structure of the driver in 16-bit ECC mode (2 KB page size)

DATA(2048B) BB CTRL RSV

BB: bad block, 2 bytes  
CTRL: 6 bytes

The storage structure of the data in NANDC buffers is the same as that in the driver.

**Figure 5-13** shows the data structure of data written to the NAND flash when the OOB length is 8 bytes. The 2056-byte valid data of the software is divided into two 1028-byte data segments, and the 28-byte ECC is calculated for each data segment. Then the data segments and ECC code are written to the NAND flash alternately.

**Figure 5-13** Data structure of data in the NAND flash (with the 2 KB page size) in 16-bit ECC mode

DATA(1028)+ECC(28)+DATA(992)+BB(2)+DATA(28)+ECC(28)+CTRL(6)

#### 4 KB Page Size

**Figure 5-14** shows the data structure of the driver in 16-bit ECC mode (4 KB page size).

**Figure 5-14** Data structure of the driver in 16-bit ECC mode (4 KB page size)

DATA(4096) BB CTRL



BB: bad blocks, 2 bytes  
CTRL: control area for software, 14 bytes

**Figure 5-15** shows the data structure of data written to the NAND flash when the OOB length is 16 bytes. The software valid data is divided into four 1032-byte data segments, and the ECC is calculated for each data segment.

Data written to the NAND flash is automatically stored as three data segments in the alternate form of 1032-byte data+28-byte ECC code. For the last data segment (1032-byte data+28-byte ECC code), the bad block flag is inserted in byte 4096 of the NAND flash.

**Figure 5-15** Data structure of data in the NAND flash (with the 4 KB page size) in 16-bit ECC mode



#### 5.2.4.4 24-Bit/1024-Byte ECC Mode

##### 2 KB Page Size

**Figure 5-16** shows the data structure of the driver in 24-bit ECC mode (2 KB page size).

**Figure 5-16** Data structure of the driver in 24-bit ECC mode (2 KB page size)



BB: bad block, 2 bytes  
CTRL: control area for software, 30 bytes

**Figure 5-17** shows the data structure of the data written to the NAND flash. The bad block is inserted in byte 2048 of the NAND flash.

**Figure 5-17** Data structure of data in the NAND flash (with the 2 KB page size) in 24-bit ECC mode



##### 4 KB Page Size

**Figure 5-18** shows the data structure of the driver in 24-bit ECC mode (4 KB page size).

**Figure 5-18** Data structure of the driver in 24-bit ECC mode (4 KB page size)





BB: bad blocks, 2 bytes  
CTRL: control area for software, 30 bytes

The software valid data is divided into four 1024 bytes+8 bytes data segments, and a 42-byte ECC is calculated for each data segment.

When being written to the NAND flash, data and ECC code in the first three data segments are stored in the alternative form. For the last data segment (1024 bytes+8 bytes+42 bytes), the bad block flag is inserted in byte 4096 of the NAND flash.

**Figure 5-19** Data structure of data in the NAND flash (with the 4 KB page size) in 24-bit ECC mode

DATA(1032)+ECC(42)+DATA(1032)+ECC(42)+DATA(1032)+ECC(42)+DATA(874)+BB(2)+DATA(126)+ECC(42)+CTRL(30)

## 8 KB Page Size

[Figure 5-20](#) shows the data structure of the driver in 24-bit ECC mode (8 KB page size).

**Figure 5-20** Data structure of the driver in 24-bit ECC mode (8 KB page size)



BB: bad block, 2 bytes  
CTRL: control area for software, 30 bytes

The software valid data is divided into eight 1024 bytes+4 bytes data segments, and a 42-byte ECC is calculated for each data segment. When being written to the NAND flash, the first seven data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+4 bytes+42 bytes), the bad block flag is inserted in byte 8192 of the NAND flash.

**Figure 5-21** Data structure of data in the NAND flash (with the 8 KB page size) in 24-bit ECC mode

DATA(1028)+ECC(42)+DATA(1028)+ECC(42)+DATA(1028)+ECC(42)+DATA(1028)+ECC(42)  
DATA(1028)+ECC(42)+DATA(1028)+ECC(42)+DATA(1028)+ECC(42)+DATA(702)+BB(2)+DATA(294)+ECC(42)+CTRL(30)

## 5.2.4.5 28-Bit/1024-Byte ECC Mode

### 2 KB Page Size

[Figure 5-22](#) shows the data structure of the driver in 28-bit ECC mode (2 KB page size).

**Figure 5-22** Data structure of the driver in 28-bit ECC mode (2 KB page size)



BB: bad blocks, 2 bytes



CTRL: control area for software, 30 bytes

The software valid data is divided into two 1024 bytes+16 bytes data segments, and a 50-byte ECC is calculated for each data segment.

When being written to the NAND flash, the first data segment and ECC code are stored alternately. For the last data segment (1024 bytes+16 bytes+50 bytes), the bad block flag is inserted in byte 2048 of the NAND flash.

**Figure 5-23** Data structure of data in the NAND flash (with the 2 KB page size) in 28-bit ECC mode



## 4 KB Page Size

[Figure 5-24](#) shows the data structure of the driver in 28-bit ECC mode (4 KB page size).

**Figure 5-24** Data structure of the driver in 28-bit ECC mode (4 KB page size)



BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes

The software valid data is divided into four 1024 bytes+8 bytes data segments, and a 50-byte ECC is calculated for each data segment.

When being written to the NAND flash, the first three data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+8 bytes+50 bytes), the bad block flag is inserted in byte 4096 of the NAND flash.

**Figure 5-25** Data structure of data in the NAND flash (with the 4 KB page size) in 28-bit ECC mode



## 8 KB Page Size

[Figure 5-26](#) shows the data structure of the driver in 28-bit ECC mode (8 KB page size).

**Figure 5-26** Data structure of the driver in 28-bit ECC mode (8 KB page size)



BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes



The software valid data is divided into eight 1024 bytes+4 bytes data segments, and a 50-byte ECC is calculated for each data segment. When being written to the NAND flash, the first seven data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+4 bytes+50 bytes), the bad block flag is inserted in byte 8192 of the NAND flash.

**Figure 5-27** Data structure of data in the NAND flash (with the 8 KB page size) in 28-bit ECC mode



## 5.2.4.6 40-Bit/1024-Byte ECC Mode

### 8 KB Page Size

[Figure 5-28](#) shows the data structure of the driver in 40-bit ECC mode (8 KB page size).

**Figure 5-28** Data structure of the driver in 40-bit ECC mode (8 KB page size)



BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes

The software valid data is divided into eight 1024 bytes+4 bytes data segments, and a 70-byte ECC is calculated for each data segment. When being written to the NAND flash, the first seven data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+4 bytes+70 bytes), the bad block flag is inserted in byte 8192 of the NAND flash.

**Figure 5-29** Data structure of data in the NAND flash (with the 8 KB page size) in 40-bit ECC mode



### 16 KB Page Size

[Figure 5-30](#) shows the data structure of the driver in 40-bit ECC mode (16 KB page size).

**Figure 5-30** Data structure of the driver in 40-bit ECC mode (16 KB page size)



BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes



The software valid data is divided into sixteen 1024 bytes+2 bytes data segments, and a 70-byte ECC is calculated for each data segment. When being written to the NAND flash, the first 15 data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+2 bytes+70 bytes), the bad block flag is inserted in byte 16384 of the NAND flash.

**Figure 5-31** Data structure of data in the NAND flash (with the 16 KB page size) in 40-bit ECC mode

DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+

DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+

DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+ECC(70)+DATA(1026)+

ECC(14)+BB(2)+ECC(56) +DATA(994)+ECC(70)+CTRL(30)

Two NANDC operations are required to write to each page. Write the 8192 bytes+16 bytes valid data to the start position of address 0 in the NANDC buffer, and then start the write-only mode of the NANDC. The ECC code generated by the NANDC for each operation is stored in the start position of the 8192 bytes+128 bytes in the internal buffer.

Reading an entire page also requires two NANDC operations, which is similar to writing to the page.

#### 5.2.4.7 64-Bit/1024-Byte ECC Mode

##### 8 KB Page Size

[Figure 5-32](#) shows the data structure of the driver in 64-bit ECC mode (8 KB page size).

**Figure 5-32** Data structure of the driver in 64-bit ECC mode (8 KB page size)

DATA(8192) BB CTRL

BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes

The software valid data is divided into eight 1024 bytes+4 bytes data segments, and a 112-byte ECC is calculated for each data segment. When being written to the NAND flash, the first seven data segments and ECC codes are stored alternately. For the last data segment (1024 bytes+4 bytes+112 bytes), the bad block flag is inserted in byte 8192 of the NAND flash.

**Figure 5-33** Data structure of data in the NAND flash (with the 8 KB page size) in 64-bit ECC mode

DATA(1028)+ECC(112)+DATA(1028)+ECC(112)+DATA(1028)+ECC(112)+DATA(1028)+ECC(112)+

DATA(1028)+ECC(112)+DATA(1028)+ECC(112)+DATA(212)+BB(2) +DATA(784)+ECC(112)+CTRL(30)



## 16 KB Page Size

[Figure 5-34](#) shows the data structure of the driver in 64-bit ECC mode (16 KB page size).

**Figure 5-34** Data structure of the driver in 64-bit ECC mode (16 KB page size)



BB: bad blocks, 2 bytes

CTRL: control area for software, 30 bytes

The software valid data is divided into sixteen 1024 bytes+2 bytes data segments, and a 112-byte ECC is calculated for each data segment. When being written to the NAND flash, the first 14 data segments and ECC codes are stored alternately. For the fifteenth data segment (1024 bytes+2 bytes+112 bytes), the bad block flag is inserted in byte 16384 of the NAND flash.

**Figure 5-35** Data structure of data in the NAND flash (with the 16 KB page size) in 64-bit ECC mode



Two NANDC operations are required to write to each page. Write the 8192 bytes+16 bytes valid data to the start position of address 0 in the NANDC buffer, and then start the write-only mode of the NANDC. The ECC code generated by the NANDC for each operation is stored in the start position of the 8192 bytes+128 bytes in the internal buffer.

Reading an entire page also requires two NANDC operations, which is similar to writing to the page.

## 5.2.5 Software Operations

### 5.2.5.1 Initializing the NAND Flash

The NAND flash is initialized as follows:

- Step 1** Write 1 to NFC\_CON[op\_mode] to enter the normal mode. Set NFC\_CON[bus\_width] and NFC\_CON[page\_size] based on the page size and bit width of the connected component, and write to NFC\_CON[ecc\_type] to set the ECC type.
- Step 2** Write to NFC\_PWIDTH based on the timing requirements for the interconnected component.
- Step 3** In query mode, write to the interrupt enable register NFC\_INTEN to mask all the interrupts; in interrupt mode, enable only the op\_done interrupt and mask other interrupts.

----End



### 5.2.5.2 Erasing the NAND Flash

The NAND flash is erased as follows:

- Step 1** Write the address of the block to be erased to NFC\_ADDRL and the erase command 0x0070\_D060 to NFC\_CMD.
- Step 2** Write 0x66d to NFC\_OP to enable the NANDC to erase the NAND flash. (Assume that the NAND flash needs three addresses and the first NAND flash needs to be erased.)
- Step 3** In query mode, check whether the value of NFC\_STATUS[nfc\_ready] is 1. If yes, go to step 4; otherwise, continue the query. In interrupt mode, check whether the value of NFC\_INTS[op\_done] is 1. If yes, go to step 4.
- Step 4** Read NFC\_STATUS[nf\_status] to check whether the NAND flash is erased successfully.

----End

### 5.2.5.3 Writing to the NAND Flash in DMA Mode

- Configure the parameters of NFC\_CON such as page size, ecc\_type, and bus\_wide based on the type of the interconnected component.
- Configure the base addresses for storing data in the DDR by setting NFC\_BADDR\_D0, NFC\_BADDR\_D1, NFC\_BADDR\_D2, NFC\_BADDR\_D3, and NFC\_BADDR\_OOB. Each base address stores 4 KB data (4-byte-aligned).
  - Set the base address register NFC\_BADDR\_D0 for the NAND flash with the 2 KB page size.
  - Set the base address register NFC\_BADDR\_D0 for the NAND flash with the 4 KB page size.
  - Set the base addresses registers NFC\_BADDR\_D0 and NFC\_BADDR\_D1 for the NAND flash with the 8 KB page size. Each base address stores 4 KB data.
  - Set the base address registers NFC\_BADDR\_D0, NFC\_BADDR\_D1, NFC\_BADDR\_D2, and NFC\_BADDR\_D3 for the NAND flash with the 16 KB page size. Each base address stores 4 KB data.
  - Set the base address register NFC\_BADDR\_OOB that specifies the storage address for the OOB data in the DDR for the NAND flash memory with the 2 KB, 4 KB, 8 KB, or 16 KB page size.
  - In ECC0 mode, configure NFC\_DMA\_LEN[len\_oob] to set the size of the OOB area.
- Set NFC\_DMA\_CTRL to 0x73 to enable the NANDC to write to the NAND flash.
- The CPU waits until the NANDC sends the DMA transfer completion interrupt or queries NFC\_DMA\_CTRL[dma\_start] until it is 0.

### 5.2.5.4 Reading the NAND Flash in DMA Mode

- Configure the parameters of NFC\_CON such as page size, ecc\_type, and bus\_wide based on the type of the interconnected component.
- Configure the base addresses for storing the read data in the DDR by setting NFC\_BADDR\_D0, NFC\_BADDR\_D1, NFC\_BADDR\_D2, NFC\_BADDR\_D3, and NFC\_BADDR\_OOB. Each base address stores 4 KB data (4-byte-aligned).
  - Set the base address register NFC\_BADDR\_D0 for the NAND flash with the 2 KB page size.



- Set the base address register NFC\_BADDR\_D0 for the NAND flash with the 4 KB page size.
- Set the base addresses registers NFC\_BADDR\_D0 and NFC\_BADDR\_D1 for the NAND flash with the 8 KB page size. Each base address stores 4 KB data.
- Set the base address registers NFC\_BADDR\_D0, NFC\_BADDR\_D1, NFC\_BADDR\_D2, and NFC\_BADDR\_D3 for the NAND flash with the 16 KB page size. Each base address stores 4 KB data.
- Set the base address register NFC\_BADDR\_OOB that specifies the storage address for the OOB data in the DDR for the NAND flash memory with the 2 KB, 4 KB, 8 KB, or 16 KB page size.
- Set NFC\_DMA\_CTRL to 0x71 to enable the NANDC to read the NAND flash.
- If only the OOB is read in DMA mode, set NFC\_DMA\_CTRL to 0x1071 to enable the NANDC to read the NAND flash.
- The CPU waits until the NANDC sends the DMA transfer completion interrupt or queries NFC\_DMA\_CTRL[dma\_start] until it is 0.

## 5.2.6 Others

Note the following:

- Reset the multi-level cell (MLC) NAND flash by following the memory manuals before using it.
- The operation commands of the NAND flash memories vary according to vendors. You need to configure the command register NFC\_CMD according to memory manuals. In addition, the number of address cycles required by the NAND flash memories of different capacities is different. Therefore, you need to configure the address\_cycles field of NFC\_OP according to memory manuals. The timings supported by various memories are also different. You need to configure the read/write pulse width register NFC\_PWIDTH and operation interval register NFC\_OPIDLE according to memory manuals.
- After configuring relevant registers and buffer, write NFC\_OP to enable the NANDC to read or write to the flash memory. After that, do not write to relevant registers; otherwise, the NANDC or NAND flash memory may be abnormal.
- After starting to read or write to the NAND flash by writing to NFC\_OP, do not read or write to the buffer of the NANDC when NFC\_STATUS[nfc\_ready] is 0. Otherwise, error data may be returned.

## 5.3 MMC/SD/SDIO Controller

### NOTE

Hi3796M V100 integrates two SDIO controllers. The SDIO0 controller supports the SDIO and SD cards, and the SDIO1 controller supports the eMMC and fSD.

### 5.3.1 Function Description

#### Functional Block Diagram

The MMC/SD/SDIO controller (MMC controller for short) controls the read/write operations on the MMC, supports various extended devices such as Bluetooth and Wi-Fi devices based on the SDIO protocol, and allows the system to boot from the MMC.

The MMC controller can control the devices that comply with the following protocols:

- SD mem-version 3.0
- SDIO-version 3.0
- MMC-version 4.41, eMMC 4.5, booting from the MMC

[Figure 5-36](#) shows the functional block diagram of the MMC controller.

**Figure 5-36** Functional block diagram of the MMC controller



#### NOTE

S indicates the slave interface and M indicates the master interface.

The MMC controller connects to the system through the internal bus. It consists of the following parts:

- Command path  
Transmits commands and receives responses.
- Data path  
Reads and writes data by working with the command path.
- Interface clock control unit  
Changes the frequency of the interface clock as required and enables or disables the interface clock. SDIO\_CLK\_OUT can be generated by dividing CCLK\_IN.

The MMC controller has the following features:

- Internal DMA data transmission
- One TX FIFO and one RX FIFO. Each FIFO is 256-word deep.
- Configurable burst size during DMA transmission and configurable FIFO threshold
- FIFO overflow and underflow interrupts to avoid errors during data transfer
- Cyclic redundancy check (CRC) generation and check for data and commands
- Programmable interface clock frequency
- MMC clock and interface clock disable in low-power mode
- 1-bit, 4-bit, or 8-bit data width based on the connected component
- Read/Write operations on data blocks with the size of 1 byte to 65,535 bytes
- Read/Write operations on stream data from/to the MMC card
- Suspend, resume, and read wait operations on the SDIO card

## Typical Application

Figure 5-37 shows the typical application circuit of the MMC controller.

**Figure 5-37** Typical application circuit of the MMC controller



The MMC controller exchanges commands and data with the connected card over a clock signal line, a bidirectional command signal line, and four or eight bidirectional data signal lines. The command signal line and data signal lines work in pull-up mode. Table 5-8 describes the pull-up resistors and the load capacitance of each signal line.

**Table 5-8** Load parameters of signal lines

| Parameter             | Min           | Max            | Description       |
|-----------------------|---------------|----------------|-------------------|
| $R_{DAT}$ , $R_{CMD}$ | 10 k $\Omega$ | 100 k $\Omega$ | Pull-up resistors |

| Parameter                    | Min | Max   | Description                                                                                                                                                                                  |
|------------------------------|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Load capacitive reactance Cx | -   | 30 pF | $C_x = C_{mmchost} + C_{bus} + C_{card}$<br>The maximum load capacitance of each card ( $C_{card}$ ) is 10 pF; therefore, the value of $C_{mmchost}$ plus $C_{bus}$ must be less than 30 pF. |
| Inductive reactance          | -   | 16 nH | $F_{pp} \leq 20 \text{ MHz}$                                                                                                                                                                 |



## CAUTION

Besides the signal lines in [Figure 5-37](#), the card slot also provides the mechanical write protection signal and card detection signal. However, the signal interfaces are not provided in [Figure 5-37](#).

## Commands and Responses

All interactions between the MMC controller and the card, including initializing the card, reading/writing to registers, querying the status, and transferring data, are implemented by using commands.

An MMC command is a segment of 48-bit serial data consisting of a start bit, a transmission bit, a command sequence, command parameters, a CRC bit, and an end bit. After receiving a command, the card returns a 48-bit or a 136-bit response based on the command type.

**Figure 5-38** Format of an MMC command



**Figure 5-39** Format of the response to an MMC command

Commands are classified into the following two types based on whether data is transferred:

- Non-data transfer command
  - The MMC controller transmits commands/receives responses to/from the card through the command signal line CMD.
- Data transfer command
  - Besides the interaction on the command line, data is also transferred through the data lines DAT0 to DAT7.
  - 1. Non-data transfer command

**Figure 5-40** shows the operations between the MMC controller and the card by running a non-data transfer command.

**Figure 5-40** Running an MMC non-data transfer command

## 2. Data transfer command

The MMC supports the following data transfer commands:

- Stream data read/write command
  - Only the MMC card supports the stream data read/write command. In this case, only the data line DAT0 is used for data transfer, and no CRC check is performed.
- Single-block read/write command
  - After this command is sent, one single data block is read or written each time. No stop command is required for stopping each data transfer.



- Multi-block read/write command
  - Predefined block count mode

Before the multi-block read/write command is sent, the block count command is transmitted to specify the number of data blocks to be transferred.
  - Open ended mode

After a read/write command is sent, a stop command is required for stopping data transfer at the end of data transfer.

The difference between the two modes lies in how the MMC controller notifies the card of the end of each data transfer. The SD card supports only the open-ended mode, whereas the MMC supports both modes.

The multi-block read/write command for the SDIO card is different. To be specific, the command parameter contains the number of data blocks to be transferred when the read/write command is sent.

Commands are classified into the following three types based on responses:

- Command without response

For example, the card reset command.
- Command with short response

For example, the data transfer command and card status query command.
- Command with long response

This type of commands are used only to read the information about the card identification (CID) and card specific data (CSD) registers of a card.

## Data Transmission

The single-block read/write command and the multi-block read/write command are widely used during data transfer. The data block during the data transfer of the SD card and MMC is 512 bytes; the block size during the data transfer of the SDIO card can be customized

### NOTE

During the data transfer by using the block read/write command, the total amount of data to be transferred must be an integral multiple of the block size.

All data transfer commands are short response commands transferred with data through data lines. [Figure 5-41](#) and [Figure 5-42](#) show the relationship between the commands, responses, and timings of data lines.

#### 1. Single-block and multi-block read operations

**Figure 5-41** Single-block and multi-block read operations

The MMC controller sends a single-block or multi-block read command to a card. When a response is being received, data is received by block. Each data block contains a CRC check bit to ensure the integrity of the transferred data.

In a single-block read operation, the data transfer is complete after the MMC controller receives a data block. In a multi-block read operation, the MMC controller needs to send a stop command to end the data transfer after receiving multiple data blocks (only in open-ended mode).

## 2. Single-block and multi-block write operations

**Figure 5-42** Single-block and multi-block write operations

The MMC controller sends a single-block or multi-block write command to a card. After receiving a response, the MMC controller starts to transmit data to the card by block. Each data block contains a CRC bit. The card performs CRC on each data block and returns the CRC status to the MMC controller to ensure proper data transfer.

In a single-block write operation, the data transfer is complete after the MMC controller transmits a data block. In a multi-block write operation, the MMC controller needs to send a stop command to end the data transfer after transmitting multiple data blocks (only in open-ended mode). After a write operation, the card may be busy in programming the flash memory. The MMC controller can perform the next operation on the card only after it confirms that the card is not busy by querying the status of the signal line DAT0.

## 3. Data transfer mode

- During the block read/write operations, the 1-/4-bit data line can be used to transfer data between the MMC controller and the card. Before sending a data transfer command, ensure that the data transfer widths of the MMC controller and card are the same (1-bit or 4-bit). You can set the data bit width of the MMC controller by configuring MMC\_CTYPE and set the data bit width of the card by transmitting the corresponding command.
- [Figure 5-43](#) shows the data transfer format in 1-bit mode, and [Figure 5-44](#) shows the data transfer format in 4-bit mode.

**Figure 5-43** Data transfer format in 1-bit mode**Figure 5-44** Data transfer format in 4-bit mode

## Voltage Switching

The MMC controller supports SD 3.0 Ultra High Speed (UHS-1) and allows the voltage to be switched in SD mode. [Table 5-9](#) describes the mapping between the transmission modes and voltages.



**Table 5-9** Mapping between transmission modes and voltages

| Mode       | Input Clock Source (MHz) | Maximum Output Clock (MHz) | Data Width | Maximum Bit Rate (MB/s) | Voltage (V) |
|------------|--------------------------|----------------------------|------------|-------------------------|-------------|
| SD_DS      | 15                       | 15                         | 1, 4       | 7.5                     | 3.3         |
| SD_HS      | 50                       | 50                         | 1, 4       | 25                      | 3.3         |
| SD_SDR12   | 15                       | 15                         | 1, 4       | 7.5                     | 1.8         |
| SD_SDR25   | 50                       | 50                         | 1, 4       | 25                      | 1.8         |
| SD_SDR50   | 75                       | 75                         | 1, 4       | 37.5                    | 1.8         |
| SD_SDR104  | 100                      | 100                        | 1, 4       | 50                      | 1.8         |
| SD_DDR50   | 50                       | 50                         | 1, 4       | 50                      | 1.8         |
| EMMC_DS    | 15                       | 15                         | 1, 4, 8    | 15                      | 3.3/1.8     |
| EMMC_HS    | 50                       | 50                         | 4, 8       | 50                      | 3.3/1.8     |
| EMMC_DDR   | 50                       | 50                         | 4, 8       | 100                     | 3.3/1.8     |
| EMMC_HS200 | 100                      | 100                        | 4, 8       | 100                     | 1.8         |

## 5.3.2 Timings and Parameters

### 5.3.2.1 Timing Parameters

Table 5-10 describes the timing parameters of the MMC interface.

**Table 5-10** Timing parameters of the MMC interface

| Parameter | Description                           | Min               | Max               | Unit |
|-----------|---------------------------------------|-------------------|-------------------|------|
| tCYC      | Card clock cycle                      | 20                | -                 | ns   |
| tWH       | High level duration of the card clock | 0.5tCYC           | 0.5tCYC           | ns   |
| tCCLK_IN  | Working clock cycle of the MMC module | 20 or 41.67       |                   | ns   |
| tCD       | SDIO_CMD output delay                 | 0.6tCCLK_IN - 5.0 | 0.6tCCLK_IN + 1.2 | ns   |
| tDD       | SDIO_DATA output delay                | 0.6tCCLK_IN - 4.7 | 0.6tCCLK_IN + 2.1 | ns   |
| tCS       | SDIO_CMD input setup time             | 5.0               | -                 | ns   |
| tCH       | SDIO_CMD input hold time              | 0.7               | -                 | ns   |

| Parameter | Description                | Min | Max | Unit |
|-----------|----------------------------|-----|-----|------|
| tDS       | SDIO_DATA input setup time | 5.3 | -   | ns   |
| tDH       | SDIO_DATA input hold time  | 0.7 | -   | ns   |

### 5.3.2.2 Interface Timings

#### Output Timing

Figure 5-45 Output timing



#### Input Timing

Figure 5-46 Input timing



### 5.3.3 Application

#### Clock Gating

When the software completes the current command or data transfer and does not start a new data transfer, the SDIO\_CLK\_OUT clock can be disabled if the MMC controller is idle.

The process is as follows:



**Step 1** Read the register MMC\_STATUS.

**Step 2** If both MMC\_STATUS[Commandfsm\_states] and MMC\_STATUS[data\_state\_mc\_busy] are 0, write 0 to MMC\_CTRL to mask the MMC interrupt, enable the DMA request, and then go to step 3; if any of MMC\_STATUS[Commandfsm\_states] and MMC\_STATUS[data\_state\_mc\_busy] is not 0, wait until timeout, and then go to step 1.

**Step 3** Write 0 to PERI\_CRG40 bit[1] to disable the corresponding clock.

If you need to restart the working clock, write 1 to PERI\_CRG40 bit[1].

----End

## Soft Reset

If the MMC controller cannot restore to the idle state due to exceptions during data transfer, you can soft-reset the MMC controller by configuring PERI\_CRG40 bit[4]. Then you can query MMC\_STATUS[Data\_busy] to check whether the MMC controller is idle.

Before using the MMC controller or after hot-plugging the card, you are advised to soft-reset the MMC controller.

## Working Clock

Before using the MMC controller, you need to set the frequency of its working clock to 50 MHz by configuring PERI\_CRG40 bit[9:8].

## Interface Clock

The clock frequency varies according to the protocols that the MMC complies with and the state of MMC. The MMC controller provides an internal even frequency divider that generates appropriate interface clocks by dividing the frequency of the working clock. The following expression describes the relationship between the frequencies of the working clock CCLK\_IN and the interface clock SDIO\_CCLK\_OUT of the MMC controller:

$$F_{SDIO\_CCLK\_OUT} = F_{CCLK\_IN} / (2 \times \text{clk\_divider})$$

Where, clk\_divider is the value of MMC\_CLKDIV[clk\_divider]. The clock frequency varies according to card types. The maximum value of  $F_{SDIO\_CCLK\_OUT}$  is 50 MHz.

Before changing the clock frequency of an MMC, ensure that no data or command is being transferred. To avoid glitches in the output clock to the MMC, you need to perform the following steps to change the clock frequency:

**Step 1** Disable the interface clock.

Set MMC\_CLKENA to 0x0000\_0000, set MMC\_CMD[Start\_cmd], MMC\_CMD[Update\_clk\_regs\_only], and MMC\_CMD[Wait\_prvdata\_complete] to 1, and then wait until MMC\_CMD[Start\_cmd] is cleared automatically.

**Step 2** Set the clock divider.

Configure MMC\_CLKDIV based on the required clock frequency, set MMC\_CMD[Start\_cmd] and MMC\_CMD[Update\_clk\_regs\_only] to 1, and then wait until MMC\_CMD[Start\_cmd] is cleared automatically.

**Step 3** Enable the interface clock again.



Set MMC\_CLKENA to 0x0000\_0001, set MMC\_CMD[Start\_cmd] and MMC\_CMD[Update\_clk\_regs\_only] to 1, and then wait until MMC\_CMD[Start\_cmd] is cleared automatically.

----End



## CAUTION

- The values of MMC\_CLKDIV and MMC\_CLKENA are loaded only after MMC\_CMD[Start\_cmd] and MMC\_CMD[Update\_clk\_only] are set to 1. After the values are loaded successfully, the MMC controller clears MMC\_CMD[Start\_cmd] automatically. If another command is being executed, a hardware locked error (HLE) interrupt is generated. In this case, you need to clear the interrupt, and then send the command again.
- When a command is being executed or data is being transferred, the clock parameters of the card cannot be changed.

## Initializing the MMC

Before commands and data are exchanged between a card and the MMC controller, you need to initialize the MMC controller by performing the following steps:

**Step 1** Configure the working clock frequency of the MMC controller. For details, see "[Working Clock](#)."

**Step 2** Soft-reset the MMC controller after the card is powered on and the command and data signal lines are pulled up and become stable. For details, see "[Soft Reset](#)."

**Step 3** Clear interrupts. Set MMC\_RINTSTS bit[15:0] to 1 to clear raw interrupt status bits.

**Step 4** Set MMC\_INTMASK bit[15:0] to 1 to enable all interrupt sources.

If data is transferred in DMA mode, set MMC\_INTMASK bit[4] and MMC\_INTMASK bit[5] to 0 to mask the TX/RX FIFO data request interrupts.

**Step 5** Set MMC\_CTRL[Int\_enable] to 1 to enable the MMC interrupt.

**Step 6** Configure the timeout parameter register MMC\_TMOUT.

**Step 7** Configure the FIFO parameter register MMC\_FIFOTH.

----End

After the preceding steps, the interface clock can be configured and commands can be transmitted to the card.

## Non-Data Transfer Command

If the MMC controller receives a response (correct response, error response, or timeout) after transmitting a command, it sets MMC\_RINTSTS bit[2] to 1. Short responses are stored in MMC\_RESP0, and long responses are stored in MMC\_RESP0 to MMC\_RESP3. MMC\_RESP3 bit[31] is the most significant bit (MSB), and MMC\_RESP0 bit[0] is the least



significant bit (LSB). After a command is transmitted, its error status is reflected by the response and the corresponding error bit of MMC\_RINTSTS.

A non-data transfer command is transmitted as follows:

- Step 1** Configure the corresponding command parameters in MMC\_CMDARG.
- Step 2** Configure the command register MMC\_CMD according to section [5.3.3 "Application."](#)
- Step 3** Wait until the MMC controller runs the command. If the command is executed, the MMC controller clears MMC\_CMD[Start\_cmd] automatically.
- Step 4** Check whether an HLE interrupt is generated by MMC\_RINTSTS bit[12].
- Step 5** Wait until the command is executed. If the MMC controller receives a response (correct response, error response, or timeout), it sets MMC\_RINTSTS bit[2] to 1, indicating that the command is executed.
- Step 6** Check whether there is any response exception and read the response value if necessary.

You can check the response timeout, response CRC error, and response error by reading MMC\_RINTSTS bit[8], MMC\_RINTSTS bit[6], and MMC\_RINTSTS bit[1] respectively.

----End



## CAUTION

- The values of MMC\_BYTCNT, MMC\_BLKSIZ, MMC\_CMDARG, and MMC\_CMD are loaded only after MMC\_CMD[Start\_cmd] is set to 1 and MMC\_CMD[Update\_clock\_registers\_only] is set to 0. After the values are loaded successfully, the MMC controller clears MMC\_CMD[Start\_cmd] automatically.
- If other commands are being executed, an HLE interrupt is generated. In this case, you need to perform the preceding operations again. When a non-data transfer command is being executed, the values of MMC\_BYTCNT and MMC\_BLKSIZ are ignored.

**Table 5-11** Reference/Default values of MMC\_CMD when a non-data transfer command is executed

| Parameter                    | Value     | Description                                                                 |
|------------------------------|-----------|-----------------------------------------------------------------------------|
| Start_cmd                    | 1         | Command transfer start command                                              |
| Update_clock_registers_onl y | 0         | Non-clock parameter update command                                          |
| data_transfer_expected       | 0         | Non-data transfer command                                                   |
| card_number                  | 0         | -                                                                           |
| cmd_index                    | Cmd index | Command ID                                                                  |
| send_initialization          | 0         | This bit is set to 1 when the command is a card reset command such as CMD0. |



| Parameter             | Value  | Description                                                                                                                                                                                                                                                                        |
|-----------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stop_abort_cmd        | 0      | This bit is set to 1 when the command is a data transfer stop command such as CMD12.                                                                                                                                                                                               |
| rsponse_length        | 0      | This bit is set to 1 when the response is a long response.                                                                                                                                                                                                                         |
| rsponse_expect        | 1      | This bit is set to 0 when a command is not responded, such as CMD0, CMD4, or CMD15.                                                                                                                                                                                                |
| Wait_prvdata_complete | 1 or 0 | The MMC controller must wait until the current data transfer command is executed before sending another command. It is recommended that this bit be fixed at 1 unless the command is used for querying the card status during data transfer or stopping the current data transfer. |
| Check_response_crc    | 1 or 0 | This bit indicates whether the MMC controller checks the responded CRC bit.                                                                                                                                                                                                        |

## Reading a Single Data Block or Multiple Data Blocks

To read a single data block or multiple data blocks, perform the following steps:

- Step 1** Write 1 to MMC\_CTRL[fifo\_reset] to reset the FIFO pointer, and then query and wait until this bit is cleared automatically.
- Step 2** Write the number of bytes to be transmitted to MMC\_BYTCNT.
- Step 3** Write the block size to MMC\_BLKSIZ.
- Step 4** Write the start address for reading data to MMC\_CMDARG.
- Step 5** Set the MMC\_CMD register based on [Table 5-12](#).

For the SD card or MMC, you need to read a single data block by using CMD17, and read multiple data blocks by using CMD18; for the SDIO card, you can read a single data block or multiple data blocks by using CMD53.

The MMC controller starts to run commands after MMC\_CMD is written. After commands are transferred to the bus, the cmd\_done interrupt is generated.

- Step 6** Check the values of MMC\_RINTSTS bit[5] and MMC\_RINTSTS bit[10]. If any or both of them are 1, read the data in the FIFO from MMC\_DATA. This ensures that the MMC controller can receive the subsequent data. In addition, check data error interrupts, that is, check the values of MMC\_RINTSTS bit[7], MMC\_RINTSTS bit[9], MMC\_RINTSTS bit[13], and MMC\_RINTSTS bit[15]. In this case, you can send a stop command to stop the data transfer by using the software.
- Step 7** If MMC\_RINTSTS bit[3] is 1, data transfer is complete. In this case, read the remaining data in the FIFO by reading MMC\_DATA.



If MMC\_CMD[Send\_auto\_stop] is set to 1 when the command is executed, the MMC controller automatically transmits a stop command to stop the data transfer. For details, see "[Configuring the Auto-Stop Function.](#)"

----End

**Table 5-12** Reference/Default values of MMC\_CMD when a single data block or multiple data blocks are read

| Parameter                   | Value     | Description                                                                                                                                                                                                                                                       |
|-----------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start_cmd                   | 1         | Command transfer start                                                                                                                                                                                                                                            |
| Update_clock_registers_only | 0         | Non-clock parameter update command                                                                                                                                                                                                                                |
| card_number                 | 0         | -                                                                                                                                                                                                                                                                 |
| send_initialization         | 0         | This bit is set to 1 when the command is a card reset command such as CMD0.                                                                                                                                                                                       |
| stop_abort_cmd              | 0         | This bit is set to 1 when the command is a data transfer stop command such as CMD12.                                                                                                                                                                              |
| send_auto_stop              | 0 or 1    | For details, see " <a href="#">Configuring the Auto-Stop Function.</a> "                                                                                                                                                                                          |
| transfer_mode               | 0         | Block transfer                                                                                                                                                                                                                                                    |
| read/write                  | 0         | This bit indicates that data is read from the card.                                                                                                                                                                                                               |
| rsponse_length              | 0         | All responses to data commands are short responses.                                                                                                                                                                                                               |
| data_transfer_expected      | 1         | Data transfer command                                                                                                                                                                                                                                             |
| rsponse_expect              | 1         | This bit is set to 0 when a command is not responded such as CMD0, CMD4, or CMD15.                                                                                                                                                                                |
| cmd_index                   | Cmd index | Command ID                                                                                                                                                                                                                                                        |
| Wait_prvdata_complete       | 1 or 0    | The master device must wait until the current data transfer command is executed before transmitting another command. It is recommended that this bit be fixed at 1 unless the command is used for querying the card status or stopping the current data transfer. |
| Check_response_crc          | 1 or 0    | This bit indicates whether the MMC controller checks the responded CRC bit.                                                                                                                                                                                       |

## Writing to a Single Data Block or Multiple Data Blocks

To write to a single data block or multiple data blocks, perform the following steps:



- Step 1** Write 1 to MMC\_CTRL[fifo\_reset] to reset the FIFO pointer, and then query and wait until this bit is cleared automatically.
- Step 2** Write the size of data to be transferred to MMC\_BYTCNT.
- Step 3** Write the block size to MMC\_BLKSIZ.
- Step 4** Write the start address for writing data to MMC\_CMDARG.
- Step 5** Write data to the FIFO by writing to MMC\_DATA. The FIFO needs to be filled with data completely at the very beginning.
- Step 6** Set the MMC\_CMD register based on [Table 5-13](#).

For the SD card or MMC, you need to read a single data block by using CMD24, and read multiple data blocks by using CMD25; for the SDIO card, you can read a single data block or multiple data blocks by using CMD53.

- Step 7** Check the values of MMC\_RINTSTS bit[4] and MMC\_RINTSTS bit[10]. If any or both of them are 1, fill the FIFO with data by writing to MMC\_DATA. In addition, check data error interrupts, that is, check the values of MMC\_RINTSTS bit[7], MMC\_RINTSTS bit[9], MMC\_RINTSTS bit[13], and MMC\_RINTSTS bit[15]. If necessary, the program can transmit a stop command to stop the data transfer. If MMC\_RINTSTS bit[3] is 1, the data transfer is complete.

If MMC\_CMD[Send\_auto\_stop] is set to 1 during command execution, the MMC controller automatically transmits a stop command to stop the data transfer. For details, see section "[Configuring the Auto-Stop Function](#)."

- Step 8** Query and wait until the value of MMC\_STATUS[data\_busy] is changed from 1 to 0.

----End

**Table 5-13** Reference/Default values of MMC\_CMD when a single data block or multiple data blocks are written

| Parameter                   | Value  | Description                                                                          |
|-----------------------------|--------|--------------------------------------------------------------------------------------|
| Start_cmd                   | 1      | Command transfer start                                                               |
| Update_clock_registers_only | 0      | Non-clock parameter update command                                                   |
| card_number                 | 0      | -                                                                                    |
| send_initialization         | 0      | This bit is set to 1 when the command is a card reset command such as CMD0.          |
| stop_abort_cmd              | 0      | This bit is set to 1 when the command is a data transfer stop command such as CMD12. |
| send_auto_stop              | 0 or 1 | For details, see section " <a href="#">Configuring the Auto-Stop Function</a> ".     |
| transfer_mode               | 0      | Block transfer                                                                       |
| read_write                  | 1      | This bit indicates that data is written to the card.                                 |
| response_length             | 0      | All responses to data commands are short responses.                                  |

| Parameter              | Value     | Description                                                                                                                                                                                                                                                       |
|------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| data_transfer_expected | 1         | Data transfer command                                                                                                                                                                                                                                             |
| rspnse_expect          | 1         | This bit is set to 0 when a command is not responded such as CMD0, CMD4, or CMD15.                                                                                                                                                                                |
| cmd_index              | Cmd index | -                                                                                                                                                                                                                                                                 |
| Wait_prvdata_complete  | 1 or 0    | The master device must wait until the current data transfer command is executed before transmitting another command. It is recommended that this bit be fixed at 1 unless the command is used for querying the card status or stopping the current data transfer. |
| Check_response_crc     | 1 or 0    | This bit indicates whether the MMC controller checks the responded CRC bit.                                                                                                                                                                                       |

## Reading/Writing Stream Data

The modes of reading/writing stream data are the same as those of reading/writing data blocks, except that MMC\_CMD[Transfer\_mode] needs to be set to 1. During a stream data transfer, the auto-stop function is required.

## Transferring Data by Using the IDMAC

The MMC controller has an internal direct memory access controller (IDMAC) that transfers data from the original address to the destination address based on the specified descriptor.

## Descriptors

The IDMAC supports the following two types of descriptors:

- Dual-buffer descriptor. For this type of descriptor, the span between two descriptors is determined by the DSL bit of MMC\_BMOD. [Figure 5-47](#) shows the structure of the dual-buffer descriptor.

**Figure 5-47** Structure of the dual-buffer descriptor



- Linked descriptor. For this type of descriptor, each descriptor points to only one buffer and the next descriptor. [Figure 5-48](#) shows the structure of the linked descriptor.

**Figure 5-48** Structure of the linked descriptor



The descriptor must be word-aligned, and each descriptor contains 16-byte control and status information. [Figure 5-49](#) shows the internal structure of 32-bit descriptors.

**Figure 5-49** Internal structure of 32-bit descriptors



DES0 is used to protect the control and status information. [Table 5-14](#) describes the definition of each bit.

**Table 5-14** Definition of each bit of DES0

| Bit | Name | Description                                                                                                                                                                      |
|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31  | OWN  | Descriptor attribute indicator<br>0: The descriptor belongs to the CPU.<br>1: The descriptor belongs to the IDMAC.<br>After completing data transfer, the IDMAC clears this bit. |



| Bit  | Name | Description                                                                                                                                                                                     |
|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30   | CES  | Error status indicator when a card is read<br>0: No error occurs.<br>1: An error occurs.                                                                                                        |
| 29:6 | RES  | Reserved                                                                                                                                                                                        |
| 5    | ER   | Descriptor link end indicator<br>0: The descriptor is not the last one on the link.<br>1: The descriptor is the last one on the link.<br>This bit is valid only for the dual-buffer descriptor. |
| 4    | CH   | Second address in DES3<br>0: address for the second buffer<br>1: address for the next descriptor<br>When this bit is 1, DES1[25:13] must be 0.                                                  |
| 3    | FS   | The descriptor contains the first data buffer when this bit is 1. If the size of the first data buffer is 0, the next descriptor contains the start data.                                       |
| 2    | LD   | The descriptor points to the last data buffer when this bit is 1.                                                                                                                               |
| 1    | DIC  | The data transfer completion interrupt is masked when this bit is 1.                                                                                                                            |
| 0    | RES  | Reserved                                                                                                                                                                                        |

DES1 is used to specify the buffer size. [Table 5-15](#) describes the definition of each bit of DES1.

**Table 5-15** Definition of each bit of DES1

| Bit   | Name | Description                                                                                                                       |
|-------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:26 | RES  | Reserved                                                                                                                          |
| 25:13 | BS2  | Number of bytes in the second data buffer. This value must be an integral multiple of 4. This field is invalid when DES0[4] is 1. |
| 12:0  | BS1  | Number of bytes in the first data buffer. This value must be an integral multiple of 4.                                           |

DES2 is the address pointer of the first data buffer. [Table 5-16](#) describes the definition of each bit of DES2.



**Table 5-16** Definition of each bit of DES2

| Bit  | Name | Description                                                                   |
|------|------|-------------------------------------------------------------------------------|
| 31:0 | BAP1 | Physical address for the first data buffer. The address must be word-aligned. |

DES3 indicates the second address. [Table 5-17](#) describes the definition of each bit of DES3.

**Table 5-17** Definition of each bit of DES3

| Bit  | Name | Description                                                                                                                                      |
|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | BAP2 | Physical address for the second data buffer when dual-buffer descriptors are used, or physical address for the next descriptor when DES0[4] is 1 |

## Initializing the IDMAC

The IDMAC is initialized as follows:

- Step 1** Configure MMC\_BMOD to set bus parameters.
  - Step 2** Configure MMC\_IDINTEN to mask unnecessary registers.
  - Step 3** Create TX/RX descriptor linked lists, configure MMC\_DBADDR, and set the start address.
  - Step 4** The IDMAC attempts to obtain descriptors from the descriptor linked lists.
- End

## Transmitting Data

The data transmission procedure is as follows:

- Step 1** The CPU creates the descriptors DES0 to DES3, sets DES0 bit[31] (OWN bit) to 1, and prepares data buffers.
- Step 2** Write data commands to MMC\_CMD.
- Step 3** Set TX\_Wmark by using MMC\_FIFOTH.
- Step 4** Obtain descriptors by using the IDMAC and check whether the value of the OWN bit is 1. If the OWN bit is not 1, wait until the CPU releases descriptors. During this process, the IDMAC enters the suspend state. Therefore, you need to configure MMC\_PLDMND to enable the IDMAC to obtain descriptors again by using the CPU. If the OWN bit is 1, the IDMAC transfers data from data buffers to the internal FIFO of the MMC controller.

### NOTE

If the interrupts are enabled, the corresponding bit of the IDMAC status register MMC\_IDSTS is updated and the OWN bit is cleared after data transfer.

----End



## Receiving Data

The data reception procedure is as follows:

- Step 1** The CPU creates the descriptors DES0 to DES3 and sets the DES0 bit[31] (OWN bit) to 1.
- Step 2** Write data read commands to MMC\_CMD.
- Step 3** Set RX\_Wmark by using MMC\_FIFOTH.
- Step 4** Obtain descriptors by using the IDMAC and check whether the value of the OWN bit is 1. If the OWN bit is not 1, wait until the CPU releases descriptors. During this process, the IDMAC enters the suspend state. Therefore, you need to configure MMC\_PLDMND to enable the IDMAC to obtain descriptors again by using the CPU.
- Step 5** If the OWN bit is 1, the IDMAC transfers data from the internal FIFO of the MMC controller to external data buffers.
- Step 6** If the interrupts are enabled, the corresponding bit of the IDMAC status register MMC\_IDSTS is updated and the OWN bit is cleared after data transfer.

----End

## Configuring the Auto-Stop Function

When multi-block data is read or written, a stop command is required to stop each data transfer. The stop command can be transmitted in non-data transfer command mode or by using the auto-stop function.

The auto-stop function is used in following scenarios:

- SD card
  - Multi-block read/write operation by using CMD18 or CMD25
- MMC card
  - Stream data read/write operation
  - Multi-block read/write operation in open-ended mode by using CMD18 or CMD25

You are advised to use the auto-stop function of the MMC controller. The configuration process is as follows:

- Step 1** Set MMC\_CMD[Send\_auto\_stop] to 1 during execution of the block transfer command.
- Step 2** After data transfer is complete, the MMC controller automatically sends a stop command to enable the card to restore to the corresponding state.
- Step 3** Read MMC\_RINTSTS[auto\_cmd\_done] to check whether the stop command is executed. The response is saved in MMC\_RESP1.

----End

## Stopping or Aborting Data Transfer

The stop command is used to end the data transfer between the MMC controller and the card, whereas the abort command is used to end the I/O data transfer only in SDIO\_IOONLY or SDIO\_COMBO mode.

The two commands are used as follows:



- Stop command

This command can be sent at any time during data transfer. Because this command is used to stop the data transfer, you need to set MMC\_CMD bit[5:0] to CMD12, MMC\_CMD bit[14] to 1, and MMC\_CMD bit[13] to 0.

- Abort command

This command is available only for SDIO\_IOONLY or SDIO\_COMBO. To abort the data transfer, you need to configure the CCCR[ASx] register of the SDIO card by using CMD52.

## Suspending and Resuming Data Transfer

The MMC controller can suspend the data transfer of a device with an SDIO card by performing a suspend operation. After a period of time, the MMC controller can resume the data transfer by performing a resume operation.

The suspend and resume operations are implemented by configuring the corresponding bits of the CCCR register of the SDIO card. The CCCR register is written or read by using the CMD52 command.

To perform a suspend operation, do as follows:

**Step 1** Query the SBS bit of the CCCR register to check whether the SDIO card supports suspend and resume operations.

**Step 2** Query the FSx and bus status (BS) bits of the CCCR register to check whether the functional device to be suspended is transferring data.

If the BS bit is 1, the device specified by the FSx bit is transferring data.

**Step 3** Set the bus release (BR) bit of the CCCR register to 1 to suspend the current data transfer.

**Step 4** Check whether the BS and the BR bits of the CCCR register are cleared.

The BS bit retains 1 when the data bus is being used. The BR bit retains 1 before the bus is released completely. When both the BR and BS bits are 0, the data transfer of the selected functional device is suspended.

**Step 5** (Optional) If the current read operation is suspended, MMC\_CTRL[Abort\_read\_data] needs to be set to 1 to reset the data transfer function of the MMC controller after the suspend operation succeeds. After reset, MMC\_CTRL[Abort\_read\_data] is cleared automatically.

**Step 6** Read MMC\_TCBCNT to query the number of transferred bytes.

----End

To perform a resume operation, do as follows:

**Step 1** Query the transfer status of the card to check whether the bus is idle.

**Step 2** If the card is disconnected, use the CMD7 command to select it. The card status can be queried by using the CMD52 or CMD53 command.

**Step 3** Check whether the device to be resumed is ready for data transfer by querying the RF bit of the CCCR register. If the RF bit is 1, the device is ready for data transfer.

**Step 4** Run the CMD52 command to write the device ID to the FS bit of the CCCR register to resume the data transfer, and enable the MMC controller to enter the data transfer state (that



is, write the block size to MMC\_BLKSIZ, and write the amount of remaining data to be transferred to MMC\_BYTCNT).

For details about the configuration of MMC\_CMDARG, see [Table 5-18](#). The configuration of MMC\_CMD is similar to the configuration during block transfer.

The data transfer is resumed after the CMD52 command is transmitted successfully. Read the resume data flag (DF) bit of the SDIO device. If this bit is 1, data transfer starts when the transfer function is resumed. If this bit is 0, no data needs to be transferred.

- Step 5** If the DF bit is 0, the MMC generates a data timeout error interrupt a period of time later during the data read operation.

----End

**Table 5-18** Reference configuration of MMC\_CMDARG when the resume operation is performed

| MMC_CMDARG | Value                                       | Description                                                |
|------------|---------------------------------------------|------------------------------------------------------------|
| Bit[31]    | 1                                           | Read/Write flag                                            |
| Bit[30:28] | 0                                           | ID of a functional device (by accessing the CCCR register) |
| Bit[27]    | 1                                           | Real-time flag, that is, write-to-read                     |
| Bit[26]    | -                                           | -                                                          |
| Bit[25:9]  | 0x0D                                        | Register address                                           |
| Bit[8]     | -                                           | -                                                          |
| Bit[7:0]   | ID of the functional device that is resumed | Write data                                                 |



## CAUTION

The MMC wakeup function is unavailable if the system enters low-power mode.

## Performing the Read Wait Operation

The read wait operation is performed to suspend the data transfer of the device that is using the SDIO card. The MMC controller determines the duration of pausing the data transfer.

The read wait operation is performed as follows:

- Step 1** Check whether the card supports the read wait operation.

Read the SRW bit of the CCCR register by using the CMD52 command. If the SRW bit is 1, all the devices supporting the card support the read wait operation.

- Step 2** Set MMC\_CTRL[Read\_wait] to 1.



**Step 3** If you want to resume the data transfer, clear MMC\_CTRL[Read\_wait].

**----End**



# Contents

---

|                                     |            |
|-------------------------------------|------------|
| <b>6 Data Steam Interfaces.....</b> | <b>6-1</b> |
| 6.1 ETH Ports.....                  | 6-1        |
| 6.1.1 Overview.....                 | 6-1        |
| 6.1.2 Function Description.....     | 6-1        |
| 6.2 TSI.....                        | 6-2        |
| 6.2.1 Overview.....                 | 6-2        |
| 6.2.2 Features.....                 | 6-3        |



## Figures

**Figure 6-1 Logic block diagram of the ETH module ..... 6-2**



# 6 Data Steam Interfaces

## 6.1 ETH Ports

### 6.1.1 Overview

The ETH module provides an Ethernet MAC interface for receiving or transmitting data at 10 Mbit/s or 100 Mbit/s in half-duplex or full-duplex mode. This module also provides the media independent interface (MII) for the embedded PHY. With the eight configurable DMAC address filtering tables, the ETH module filters input frames received over the ETH port, limiting the traffic of the CPU port to protect the CPU against heavy traffic.

### 6.1.2 Function Description

The ETH module has the following features:

- One ETH MAC
- 10 Mbit/s or 100 Mbit/s speed
- Full-duplex or half-duplex mode
- MII for the embedded PHY
- Collision backoff and retransmission and late collision in half-duplex mode
- Pause frame transmission in full-duplex mode
- Frame length validity detection for discarding runt and giant frames
- Cyclic redundancy check (CRC) on received frames. Frames with CRC errors are discarded.
- CRC on frames to be transmitted
- Short frame filling
- Outloop in full-duplex mode
- MDIO interfaces with configurable clock frequencies
- Traffic limitation to prevent traffic attacks against the CPU
- Count of the received and transmitted frames
- Eight configurable DMAC address filtering tables
- Control over whether to receive or discard broadcast frames, multicast frames, and unicast frames based on configuration
- 802.3az EEE



- Wake-on-LAN (WoL)

Figure 6-1 shows the logic block diagram of the ETH module.

**Figure 6-1** Logic block diagram of the ETH module



## 6.2 TSI

### 6.2.1 Overview

The TSI module is used to parse and demultiplex MPEG2 TSs complying with the standards of the ISO 13818-1 (GB 17975-1) system layer. It supports two DVB TS serial inputs, three internal memory TS inputs, and simultaneous processing of two TSs.



## 6.2.2 Features

The TSI module has the following features:

- Support for the MPEG2 TSs that comply with the ISO 13818-1 system layer standard
- Three internal memory TS inputs
- Maximum 360 Mbit/s processing rate
- Sync detection of 188-/204-byte TS packets
- 96 packet identifier (PID) channels
- DVB common scramble algorithm (CSA) 2.0 descrambling
- AES cipher block chaining (CBC) and electronic codebook (ECB) descrambling algorithms (residual blocks are not descrambled)
- AES IPTV CSA descrambling algorithm
- 3DES CBC and ECB descrambling algorithms (residual blocks are not descrambled)
- 32 groups of odd and even keys
- Advanced CA interfaces
- 96 groups of 16-byte filters
- TS recording
- Start code detect (SCD) extraction from eight channels
- Data reception in interrupt or query mode



# Contents

---

|                                 |            |
|---------------------------------|------------|
| <b>7 Video Encoder.....</b>     | <b>7-1</b> |
| 7.1 Overview .....              | 7-1        |
| 7.2 VEDU.....                   | 7-1        |
| 7.2.1 Features.....             | 7-1        |
| 7.2.2 Function Description..... | 7-2        |
| 7.3 JPGE.....                   | 7-4        |
| 7.3.1 Features.....             | 7-4        |
| 7.3.2 Function Description..... | 7-5        |



## Figures

|                                                              |     |
|--------------------------------------------------------------|-----|
| <b>Figure 7-1</b> Function block diagram of the VEDU .....   | 7-3 |
| <b>Figure 7-2</b> Functional block diagram of the JPGE ..... | 7-5 |



# 7 Video Encoder

## 7.1 Overview

The video encoder consists of an embedded video encoding/decoding unit (VEDU) and video firmware (VFMW) running on the ARM processor, providing the maximum performance of 1080p@30 fps. With the features of low CPU usage, low bus bandwidth, short delay, and low power consumption, the VENC applies to various services such as video phone and video transcoding.

The JPEG encoder consists of an embedded hardware accelerator unit JPEG encoder (JPGE) and a VFMW. The JPGE can take snapshots with maximum 67 megapixels and encode Motion-JPEG (MJPEG) high-definition (HD) images.

## 7.2 VEDU

### 7.2.1 Features

The VEDU has the following features:

- ITU-T H.264 High Profile/Main Profile/Baseline Profile@L5 encoding
  - Motion prediction with 1/2 or 1/4 pixel precision
  - Inter-prediction of four subblock types (16x16, 16x8, 8x16, and 8x8)
  - Prediction modes of intra 4x4, intra 8x8, and intra 16x16
  - Deblocking filtering
  - Trans4x4 and trans 8x8
  - Context-based adaptive binary arithmetic coding (CABAC) and context-based adaptive variable-length coding (CAVLC) entropy encoding
  - I\_PCM encoding
- Support for the following video input formats:
  - Semi-planar YCbCr4:2:0
  - Planar YCbCr4:2:0
  - Package YUYV4:2:2
- H.264 video encoding performance
  - 1x1080p@30 fps H.264 encoding



- 2x720p@30 fps H.264 encoding
- Configurable resolutions of input images
  - Minimum image resolution: 160 x 64
  - Maximum image resolution: 1920 x 2048
  - Image width or height step: 4
- Region of interest (ROI) encoding
  - Encoding of a maximum of eight ROIs
  - ROI encoding enable/disable control
- CBR mode and VBR mode
- Output bit rate ranging from 32 kbit/s to 20 Mbit/s
- Multi-channel encoding



## CAUTION

Before video encoding, you can process images by using the video output unit (VOU). For example, you can implement deinterlacing, scaling, and icon overlapping.

### 7.2.2 Function Description

Figure 7-1 illustrates the functions of the VEDU.

As shown in Figure 7-1, the VEDU hardware implements functions based on the protocols and algorithms that require a large amount of operands, such as motion estimation, inter-prediction, intra-prediction, motion vector prediction, transform/quantization, inverse transform/inverse quantization, variable length code (VLC) encoding, stream generation, and deblocking filtering. The VFMW controls the bit rate and handles interrupts.

Before the VEDU hardware is enabled for video encoding, the upper-layer software and VFMW allocate three types of buffers for the VEDU in the DDR SDRAM:

- Input image buffer: The VEDU reads the original images to be encoded from this buffer during encoding. This buffer is generally written by the video input unit.
- Reconstruction/Reference image buffer: The VEDU writes reconstruction images to the buffer during encoding. These reconstruction images are used as the reference images of subsequent images. When encoding P frames, the VEDU reads reference images from this buffer.
- Stream buffer: This buffer is used to store encoded streams. The VEDU writes streams to this buffer during encoding. This buffer is read by software.

**Figure 7-1** Function block diagram of the VEDU

The VEDU performs encoding as follows:

- Step 1** The upper-layer software allocates an input image buffer and creates encoding channels.
- Step 2** The VFMW allocates a reconstruction image/reference image buffer and a stream buffer and creates contexts. During multi-channel encoding, the VFMW allocates a reconstruction image/reference image buffer, a stream buffer, and contexts for each encoding channel. Therefore, each encoding channel is independent of others.
- Step 3** The VFMW obtains the pointer of the input image buffer from the upper-layer software.
- Step 4** The VFMW configures the registers of the VEDU and enables the VEDU to encode a frame.
- Step 5** The VEDU reports an interrupt after encoding a frame.



- Step 6** The VFMW handles the interrupt, switches the buffer, adjusts the pointer, controls the bit rate, and then repeats step 3 for encoding the next frame.
- Step 7** The upper-layer software obtains streams from the VFMW.
- Step 8** The VFMW releases the reconstruction image/reference image buffer and the stream buffer and deletes contexts.
- Step 9** The upper-layer software destroys encoding channels.

----End

The VEDU can be soft-reset separately. For details, see section 3.2 "Reset."

## 7.3 JPGE

### 7.3.1 Features

The JPGE has the following features:

- ISO/IEC 10918-1 (CCITT T.81) baseline process (DCT sequential) encoding.
- Encoding of images that are sub-sampled in format of YCbCr4:2:0, YCbCr4:2:2, or YCbCr4:4:4
- Interleaved organization for the minimum coded unit (MCU)
- Support for multiple input image formats:
  - Planar YCbCr4:2:0
  - Planar YCbCr4:2:2
  - Planar YCbCr4:4:4
  - Semi-planar YCbCr4:2:0
  - Semi-planar YCbCr4:2:2
  - Package YUYV
- Maximum 1080p@30 fps encoding
- Configurable resolutions of input images
  - Minimum image resolution: 32 x 32
  - Maximum image resolution: 8192 x 8192
  - Image width or height step: 4
- Configurable quantization tables
  - An independent quantization table for the Y component, Cb component, and Cr component respectively



#### CAUTION

Before JPEG encoding, you can process images by using the VOU. For example, you can implement deinterlacing, scaling, and icon overlapping.

### 7.3.2 Function Description

Figure 7-2 shows the functional block diagram of the JPGE.

Based on the protocols that require a large number of operands, the JPGE supports level shift, discrete cosine transform (DCT), quantization, scanning, VLC encoding, and stream generation. The VFMW configures quantization tables and handles interrupts.

Before the JPGE is enabled for video encoding, the upper-layer software and VFMW allocate two types of buffers for the JPGE in the DDR SDRAM:

- Input image buffer: The JPGE reads the original images to be encoded from this buffer during encoding. This buffer is generally written by the video input unit.
- Stream buffer: This buffer is used to store output encoded streams. The JPGE writes encoded streams to this buffer after encoding. This buffer is read by software.

Figure 7-2 Functional block diagram of the JPGE



The JPGE performs encoding as follows:

**Step 1** The upper-layer software allocates an input image buffer and creates encoding channels.



- Step 2** The VFMW allocates a stream buffer and creates contexts. During multi-channel encoding, the VFMW allocates a stream buffer and contexts for each encoding channel. Therefore, each encoding channel is independent of others.
- Step 3** The VFMW obtains the pointer of the input image buffer from the upper-layer software.
- Step 4** The VFMW configures the registers of the JPGE and enables the JPGE to encode a frame.
- Step 5** The JPGE reports an interrupt after encoding a frame.
- Step 6** The VFMW handles the interrupt, switches the buffer, adjusts the pointer, and then repeats step 3 to encode the next frame (MJPEG) or exits (snapshots of JPEG images).
- Step 7** The upper-layer software obtains streams from the VFMW.
- Step 8** The VFMW releases the stream buffer and deletes contexts. Then encoding stops.
- Step 9** The upper-layer software destroys encoding channels.

----End

The JPGE can be soft-reset separately. For details, see section 3.2 "Reset."



# Contents

|                                  |            |
|----------------------------------|------------|
| <b>8 Video Decoder .....</b>     | <b>8-1</b> |
| 8.1 VDH .....                    | 8-1        |
| 8.1.1 Overview .....             | 8-1        |
| 8.1.2 Features .....             | 8-1        |
| 8.1.3 Function Description ..... | 8-2        |
| 8.2 JPDG .....                   | 8-3        |
| 8.2.1 Overview .....             | 8-3        |
| 8.2.2 Features .....             | 8-3        |
| 8.3 PGD .....                    | 8-4        |
| 8.3.1 Overview .....             | 8-4        |
| 8.3.2 Features .....             | 8-4        |



## Figures

**Figure 8-1** Architecture of the video decoder ..... 8-2



# 8 Video Decoder

## 8.1 VDH

### 8.1.1 Overview



#### CAUTION

Hi3796M V100 has an embedded video decoder that supports the H.264, H.265, MPEG1, MPEG2, MPEG4, AVS, VC1 (including WMV9), VP6, and VP8 protocols and provides superior video post-processing functions.

The video decoding module for high-definition (VDH) consists of the VFMW running on the ARM processor and an embedded video decoding engine. The VFMW obtains streams from the upper-layer software, parses the streams, and calls the video decoding engine to generate the decoding image sequences. Under the control of the upper-layer software, the video output unit (VOU) outputs the sequences to a monitor or other devices.

### 8.1.2 Features

The VDH has the following features:

- ITU-T H.265 Main Profile@L5.0 high-tier (or lower levels)
  - Maximum 4K x 2K (3840 x 2160) video resolution
  - Maximum 100 Mbit/s or 4K x 2K@30 fps decoding rate
- ITU-T H.264 High Profile@L5.1 (or lower levels)
  - Maximum 4K x 2K (3840 x 2160) video resolution
  - Maximum 135 Mbit/s or 4K x 2K@30 fps decoding rate
- ISO/IEC 13818-2 (MPEG2) Main Profile@high level and backward-compatible with MP@ML, MP@LL, SP@ML, and ISO/IEC 11172-2 (MEPG1)
  - Maximum 1080p (1920 x 1080) video resolution
  - Maximum 80 Mbit/s or 60 fps decoding rate
- ISO/IEC 14496-2 (MPEG4) Advanced Simple Profile@L0–5, compatible with the short header format, ISO/IEC 14496-2 Simple Profile@L0–3, and DivX3/4/5/6

- Maximum 1080p (1920 x 1080) video resolution
- Maximum 50 Mbit/s or 60 fps decoding rate
- AVS baseline@L6.0
  - Maximum 1080p (1920 x 1080) video resolution
  - Maximum 50 Mbit/s or 60 fps decoding rate
- VC1 SP@ML, MP@HL, and AP@L3
  - Maximum 1080p (1920 x 1080) video resolution
  - Maximum 45 Mbit/s or 60 fps decoding rate
- VP6
  - Maximum 1080p (1920 x 1080) video resolution
  - Maximum 50 Mbit/s or 60 fps decoding rate
- VP8
  - Maximum 1080p (1920 x 1080) video resolution
  - Maximum 50 Mbit/s or 60 fps decoding rate

### 8.1.3 Function Description

Figure 8-1 shows the architecture of the video decoder.

**Figure 8-1** Architecture of the video decoder





- VDH: a video decoding engine that supports multiple protocols
- VFMW: a software component running on the master processor for scheduling the VDH
- Message pool: a memory located in the external SDRAM for exchanging the messages between the VFMW and the VDH. It can be read and written by both the VDH and VFMW.

The VDH and VFMW interact with each other in the following two modes:

- The VDH and VFMW interact with each other to decode streams by slices. Specifically, the VFMW decodes the slice header and the streams before the slice header, and the VDH decodes the slice data and the streams after the slice data.
- During multi-channel decoding, the VFMW enables the VDH by frames in time-division multiplexing (TDM) mode.

The video decoding process is as follows:

**Step 1** Create a video decoder, and initialize it.

**Step 2** Store streams into the stream buffer.

**Step 3** Obtain images over the image output interface of the VFMW.

**Step 4** Release the buffer that stores the images over the frame recycle interface of the VFMW after the images are displayed.

**Step 5** Repeat step 2 to step 4 until decoding is complete.

**Step 6** Destroy the video decoder after all streams are played.

----End

## 8.2 JPGD

### 8.2.1 Overview

The Joint Photographic Experts Group decoder (JPGD) in an HD chip supports JPEG and MJPEG picture decoding.

### 8.2.2 Features

The JPGD has the following features:

- Advanced eXtensible interface (AXI) and advanced peripheral bus (APB) interface
- Interrupts
- ITU-T81 baseline profile decoding. That is:
  - Decoding in five YUV JPEG picture formats: YUV 4:0:0, YUV4:2:0, YUV4:2:2 1x2, YUV4:2:2 2x1, and YUV 4:4:4
  - A maximum of four Huffman tables including two direct coefficient (DC) tables and two alternating coefficient (AC) tables
  - A maximum of three quantization tables
  - Sequential decoding
  - Discrete cosine transform-based (DCT-based) JPEG decoding
  - 8-bit depth sampling



- Interleaved scanning
- 1/2, 1/4, or 1/8 frequency domain scaling, significantly reducing memory and bandwidth usage during decoding
- Decoding of static pictures with the resolution of 8096 x 8096 at the maximum and 1 x 1 at the minimum
- Semi-planar output storage format with the maximum resolution of 8096 x 8096
- Decoding of compressed streams by segment
- 1-channel Motion-JPEG 1080p@40 fps, satisfying various decoding systems that have high requirements on real-time performance
- AC or DC decoding error reporting
- Conversion from YUV to RGB
  - Allows the 4:0:0, 4:2:0, 4:2:2 2x1, and 4:2:2 1x2 formats to be up-sampled as the 4:4:4 format.
  - Supports the maximum resolution of 8096 x 8096 and minimum resolution of 8 x 8.
  - Supports the ARGB8888 and ABGR8888 output formats.
  - Supports configurable global alpha.
  - Allows the output to be cropped in any position and in any size.
  - Allows the output to be written to any address of the DDR (4-byte-aligned).
- Standby processing
  - YUV output standby
  - RGB output standby

## 8.3 PGD

### 8.3.1 Overview

The PNG and GIF decoder (PGD) is a hardware acceleration module that works with the software to decode PNG and GIF pictures.



Currently, PNG pictures are decoded by hardware, and GIF pictures are decoded by software.

### 8.3.2 Features

The PGD has the following features:

- APB and AXI interfaces
  - Provides an APB interface for configuring registers.
  - Provides an AXI for reading or writing data.
  - The internal working clock and AXI clock are the same.
- Picture size
  - Supports the maximum resolution of 8191 x 8191.
  - Supports the minimum resolution of 5 x 5 for decoding of interlaced pictures.
  - Supports the minimum resolution of 1 x 1 for decoding of non-interlaced pictures.
- Chunk processing



- Decodes the image data (IDAT) chunks.
- Discards the chunks excluding IDAT chunks.
- Performs CRC check on IDAT chunks.
- Decompression of Z-lib streams (including Huffman decoding and deflate decoding)
  - Supports the Z-lib stream input format.
  - Decompresses the data that is compressed in three Huffman compression modes including dynamic Huffman compression mode, fixed Huffman compression mode, and non-compression mode.
  - Supports the deflate decoding by using the maximum 32 KB deflate window.
  - Performs Adler32 check on the decompressed Z-lib streams (the data in IDAT chunks forms a Z-lib stream).
  - Does not support the dictionary (dictid).
- Pass convergence
  - Pass convergence is not supported by the hardware.
- Line filtering
  - Supports five filtering modes: non-filtering mode, upper adjacent filtering mode, left adjacent filtering mode, averaging filtering mode (referencing the values of upper adjacent and left adjacent points), and adaptive filtering mode.
  - Filters the lines of interlaced or non-interlaced pictures.
  - Filters PNG pictures in all color formats.
- Data format conversion
  - Supports the following input formats: Gray: 1 bit/2 bits/4 bits/8 bits/16 bits, BRG: 8 bits/16 bits, CLUT: 1 bit/2 bits/4 bits/8 bits, Agray: 8 bits/16 bits, and ABGR: 8 bits/16 bits.
  - Reverts the pixel sequence of one byte in the format of Gray 1 bit/2 bits/4 bits or CLUT 1 bit/2 bits/4 bits.
  - Converts the format of Gray 1 bit/2 bits/4 bits into Gray 8 bits by stuffing with 0 or gray value.
  - Converts the format of Gray 8 bits/16 bits into BGR 8 bits/16 bits, and converts the format of AGray 8 bits/16 bits into ABGR 8 bits/16 bits.
  - Converts the format of Gray 8 bits/16 bits into AGray 8 bits/16 bits, converts the format of BGR 8 bits/16 bits into ABGR 8 bits/16 bits, and sets the transparent color.
  - Converts the format of AGray 8 bits/16 bits into Gray 8 bits/16 bits, and converts the format of ABGR 8 bits/16 bits into BGR 8 bits/16 bits.
  - Converts the format of BGR 8 bits/16 bits into RGB 8 bits/16 bits, and converts the format of ABGR 8 bits/16 bits into ARGB 8 bits/16 bits.
  - Converts the format of AGray 8 bits/16 bits into GrayA 8 bits/16 bits, and converts the format of ABGR/ARGB 8 bits/16 bits into BGRA/RGBA 8 bits/16 bits.
  - Converts a 16-bit component into a 8-bit component by discarding lower eight bits or based on the format H8 + ((L8 - H8 > 128) ? 1:0).
  - Converts the format of AGRB8888 into ARGB4444, ARGB1555, RGB 565, RGB 555, and RGB 444 by discarding lower bits.
  - The final effect is displayed after the preceding effects are added in sequence. The effect of each filter can be bypassed. If the input format does not match a filter, its filtering effect is bypassed automatically.
- PNG premultiply



- Data extraction after the decompression of Z-lib streams

The PGD needs to support Z-lib decoding for kernel decoding. The hardware does not support the stream resuming function. If the specified stream length is exceeded during decoding, the hardware stops writing data and reports an error.
- Error tolerance
  - Reports the CRC error.
  - Reports the Adler32 error.
  - Supports the Z-lib stream, and reports the error of the cm field, cinfo field, fdict field, btype field, lenth field, hlit field, or fdict field.
  - Reports the error that occurs during Huffman decoding.
  - Dynamically reports the error that occurs during Huffman copy.
  - Reports the filter type error.
  - Supports the rounding control (RDC) module, and reports the buffer overflow error.
  - Supports the filter (FLT) module, and reports the buffer overflow error.
  - Supports the format (FMT) module, and reports the buffer overflow error.
- Software and hardware interfaces
  - Sets the information about a picture including the picture width, picture height, bit depth, color format, interlaced mode, filtering mode, and compression mode.
  - Sets the start and end addresses for a stream buffer.
  - Sets the start and end addresses for storing streams.
  - Sets the start address, line width, and end address (Z-lib decoding) for storing the target data.
  - Sets the address and line width for storing pass data.
  - Sets the start address for the deflate window buffer.
  - Sets the start and end addresses for filtering upper adjacent data.
  - Selects the PNG decoding or Z-lib decoding mode.
  - Starts PNG decoding.
  - Continues PNG decoding after streams are resumed.
  - Supports the resuming stream interrupt, decoding completion interrupt, and decoding error interrupt.
  - Masks the resuming stream interrupt, decoding completion interrupt, and decoding error interrupt.
  - Determines whether to continue decoding when an error occurs.
  - Collects statistics on error chunks.



# Contents

---

|                                    |            |
|------------------------------------|------------|
| <b>9 Graphics Processing .....</b> | <b>9-1</b> |
| 9.1 TDE.....                       | 9-1        |
| 9.1.1 Overview.....                | 9-1        |
| 9.1.2 Function Description.....    | 9-1        |
| 9.2 GPU (3D Acceleration) .....    | 9-2        |
| 9.3 VPSS .....                     | 9-2        |
| 9.3.1 Overview.....                | 9-2        |
| 9.3.2 Features.....                | 9-3        |



# 9 Graphics Processing

## 9.1 TDE

### 9.1.1 Overview

The TDE draws graphics using hardware, which reduces the CPU usage and improves the memory bandwidth utilization. The TDE reads and writes bitmap data, filtering and scaling coefficients, parameters of linked list nodes, and linked lists over the advanced eXtensible interface (AXI) master bus, and obtains register configuration information over the advanced peripheral bus (APB) slave interface.

The TDE processes graphics using Source 1 and Source 2 as follows:

- Source 1 implements direct copying and direct filling functions during single-source operations.
- Source 2 implements complex functions, such as scaling and anti-flicker, during single-source operations.
- Source 1 and Source 2 collaborate to implement operations such as color blending and raster operation (ROP), and to process images in the macroblock format.
- Source 1 bitmap and Output bitmap supports images in the following formats: RGB444, RGB555, RGB565, RGB888, ARGB4444, ARGB1555, ARGB8565, ARGB8888, CLUT1, CLUT2, CLUT4, CLUT8, ACLUT44, ACLUT88, A1, A8, YCbCr888, AYCbCr8888, YCbCr422, byte, half-word, YCbCr400MB, YCbCr422MBH, YCbCr422MBV, YCbCr420MB, and YCbCr444MB.
- Source 2 bitmap supports images in the following formats: RGB444, RGB555, RGB565, RGB888, ARGB4444, ARGB1555, ARGB8565, ARGB8888, CLUT1, CLUT2, CLUT4, CLUT8, ACLUT44, ACLUT88, A1, A8, YCbCr888, AYCbCr8888, YCbCr422, YCbCr400MB, YCbCr422MBH, YCbCr422MBV, YCbCr420MB, and YCbCr444MB.

### 9.1.2 Function Description

The TDE has the following features:

- Only the little endian system
- Configurable formats for Source 1 bitmap, Source 2 bitmap, and Output bitmap
- Gamma correction and contrast and luminance adjustment
- Color lookup tables (CLUTs)
- Conversion between RGB and YCbCr



- Direct copying
- Direct filling
- 2D resize
- Anti-flicker
- Clipping
- Alpha blending
- ROP
- Colorkey operation
- Programmable scanning mode
- Clip mask
- Software interfaces in linked list mode
- Status interrupts

## 9.2 GPU (3D Acceleration)

The GPU provides the OpenGL ES2.0/1.1 and OpenVG1.1 standard graphics APIs and integrates the dedicated 3D graphics acceleration engine to implement functions such as geometry processing, pixel processing, memory management, and power management. It has the following superior graphics processing capabilities:

- Comprehensive programmable geometry and pixel processing algorithms, which rapidly process primitives, textures, pixels, and templates
- Support for various input/output formats (including YCbCr) and special effect processing of decoded video data
- 16xFSAA anti-aliasing
- Dynamic frequency scaling (DFS)

## 9.3 VPSS

### 9.3.1 Overview

The video processing subsystem (VPSS) processes videos before encoding or after decoding, including VC1, deinterlacing, deringing, scaling, sharpening, aspect ratio conversion, and rotation.

It has the following features:

- Processing of maximum 4096 x 2304 video source in a single frame
- Maximum two video outputs
- Configuration of register linked lists
- Span of 4 KB boundary
- Input data format of semi-planar 420/422, planar 400/420/422/444/411/410, or package 422 YUYV/YVYU/UYVY
- Output data format of semi-planar 420/422
- Input data format of TILE420/400



- Outstanding configuration
- Memory low-power mode by using clock gating
- Soft reset at any time

### 9.3.2 Features

- VC1: This function is used to map video data based on specific protocols.
- Deinterlacing: The deinterlacing (DEI) module restores the interlaced video source to the progressive video source.
- Deringing: The deringing (DR) module compensates the high-frequency component loss due to video compression and eliminates the ring on the image edge.
- Scaling: The zoom engine (ZME) module supports one to eight times magnification or minification of images with any resolution.
- Image sharpening: The luma transient improvement (LTI) and chroma transient improvement (CTI) modules extract high-frequency components from images before scaling and compensate frequencies for the images processed by the scaler. In this way, image edges are sharpened and contours are clear.
- Aspect ratio conversion: This function is used to implement the conversion between the 4:3 and 16:9 aspect ratios by adding or deleting picture borders.
- Rotation: Rotation by 90 or 270 degrees is supported. The output data format is semi-planar 420, and the input data format must be semi-planar 420 or semi-planar 422.



# Contents

|                                       |             |
|---------------------------------------|-------------|
| <b>10 Audio/Video Interfaces.....</b> | <b>10-1</b> |
| 10.1 VDP.....                         | 10-1        |
| 10.1.1 Function Description.....      | 10-1        |
| 10.2 HDMI TX.....                     | 10-4        |
| 10.2.1 Overview.....                  | 10-4        |
| 10.2.2 Function Description.....      | 10-4        |
| 10.2.3 Operating Modes.....           | 10-7        |
| 10.3 AIAO.....                        | 10-7        |
| 10.3.1 Overview.....                  | 10-7        |
| 10.3.2 Function Description.....      | 10-8        |



## Figures

|                                                                       |       |
|-----------------------------------------------------------------------|-------|
| <b>Figure 10-1</b> Logic block diagram of the HDMI TX interface ..... | 10-5  |
| <b>Figure 10-2</b> Typical application of the HDMI .....              | 10-5  |
| <b>Figure 10-3</b> Logic block diagram of AIAO .....                  | 10-9  |
| <b>Figure 10-4</b> Typical application of the AIAO module .....       | 10-10 |



# 10 Audio/Video Interfaces

## 10.1 VDP

### 10.1.1 Function Description

The main display interface of the video display processor (VDP) has the following features:

#### NOTE

The VDP for Hi3796M V100 does not contain the G2, G3 graphics surfaces. It only supports the HDMI and CVBS output.

- Maximum 3840 x 2160 output resolution for the main video surface
- Overlapping of four surfaces, including two graphics surfaces (G0 and G1) and two video surfaces (V0 and V1)
- Video processing after overlapping (VP)
- Graphics processing after overlapping (GP0)
- VDC\_V0 surface
  - Input data formats: semi-planar YCbCr 4:2:0 and semi-planar YcbCr 4:2:2
  - Variable input/output resolution. The minimum input/output resolution is 32 x 32, the maximum input resolution is 1920 x 2160, and the maximum output resolution is 3840 x 2160.
  - Static frames (mute) and chrominance up sampling
  - Global alpha value
  - CSC between YCbCr and RGB at the video layer and the adjustment of luminance, contrast, hue, and saturation
  - Horizontal/Vertical scaling
  - 8-order horizontal luminance filtering and 4-order horizontal chrominance filtering. For each type of filtering, 32 groups of configurable filtering coefficients are provided.
  - 4-order vertical luminance filtering and 4-order vertical chrominance filtering. For each type of filtering, 32 groups of configurable filtering coefficients are provided.
  - Super resolution (SR)
  - 3D videos (side-by-side, top-and-bottom, and frame packing)
  - LetterBox
- VDC\_V1 surface



- Input data formats: semi-planar YCbCr 4:2:0 and semi-planar YCbCr 4:2:2
- Variable input/output resolution, 32 x 32 at the minimum and 1920 x 1080 at the maximum
- 16 regions
- Static frames (mute) and chrominance up sampling
- Global alpha value
- CSC between YCbCr and RGB at the video layer and the adjustment of luminance, contrast, hue, and saturation
- 4-order vertical chrominance up sampling
- 3D videos (side-by-side, top-and-bottom, and frame packing)
- LetterBox

#### NOTE

The G1 and G0 graphics surfaces of the VDP for Hi3796M V100 support the CLUT format, but G0 and G1 cannot use the CLUT format at the same time.

- **GDC\_G0**
  - Various package RGB and YUV data formats. For details, see the user guide of GDC\_G0.
  - CLUT data format
  - Variable input/output resolution, 32 x 32 at the minimum and 1920 x 1080 at the maximum
  - Three data extension modes
  - Colorkey processing
  - Premultiplied data formats
  - Global alpha and pixel alpha
  - 3D graphics (side-by-side, top-and-bottom, and frame packing)
- **GDC\_G1**
  - Various package RGB and YUV data formats. For details, see the user guide of GDC\_G1.
  - Variable input/output resolution, 32 x 32 at the minimum and 1920 x 1080 at the maximum
  - Three data extension modes
  - Colorkey processing
  - Premultiplied data formats
  - Global alpha and pixel alpha
  - 3D graphics (side-by-side, top-and-bottom, and frame packing)
- **GDC\_GP0**
  - Variable input/output resolution. The minimum input/output resolution is 32 x 32, the maximum input resolution is 1920 x 1080, and the maximum output resolution is 3840 x 2160.
  - 8-order 8-phase horizontal scaling and 4-order 16-phase vertical scaling
  - Sharpening
  - CSC and adjustment of luminance, contrast, hue, and saturation
  - 3D graphics (side-by-side, top-and-bottom, and frame packing)

The VDP auxiliary display interface has the following features:



### NOTE

The VDP auxiliary display interface for Hi3796M V100 supports SD outputs.

- Compliance with the CGMS-A standard, including 480i@60 Hz and 576i@50 Hz
- CVBS output
- (M) NTSC or NTSC-J output
- (B, D, G, H, I) PAL, (N) PAL, (Nc) PAL, or (M) PAL output
- Support for séquentiel couleur à mémoire (SECAM)
- Compliance with the Macrovision7.1 L1 standard
- Support for various vertical blanking interval (VBI) standards: Teletext, Closed Caption, CGMS, WSS, and VPS
- Overlapping of three surfaces, including one graphics surface (G4) and two video surfaces (V3 and V4)
- Processing after graphics overlapping (GP1)

### NOTE

The V3/V4/G4 surface of the Hi3796M V100 VDP supports the SD resolution.

- VDC\_V3 surface
  - Input data formats: semi-planar YCbCr 4:2:0 and semi-planar YCbCr 4:2:2
  - Variable input/output resolution, 32 x 32 at the minimum and 720 x 576 at the maximum
  - Static frames (mute) and chrominance up sampling
  - Global alpha value
  - CSC between YCbCr and RGB at the video layer and the adjustment of luminance, contrast, hue, and saturation
  - Horizontal/Vertical scaling
  - 8-order horizontal luminance filtering and 4-order horizontal chrominance filtering. For each type of filtering, 32 groups of configurable filtering coefficients are provided.
  - 4-order vertical luminance filtering and 4-order vertical chrominance filtering. For each type of filtering, 32 groups of configurable filtering coefficients are provided.
  - LetterBox
- VDC\_V4 surface
  - Input data formats: semi-planar YCbCr 4:2:0 and semi-planar YCbCr 4:2:2
  - Variable input/output resolution, 32 x 32 at the minimum and 720 x 576 at the maximum
  - 16 regions
  - Static frames (mute) and chrominance up sampling
  - Global alpha value
  - CSC between YCbCr and RGB at the video layer and the adjustment of luminance, contrast, hue, and saturation
  - 4-order vertical chrominance up sampling
  - LetterBox
- GDC\_G4
  - Various package RGB and YUV data formats. For details, see the user guide of GDC\_G4.



- Variable input/output resolution, 32 x 32 at the minimum and 720 x 576 at the maximum
- Three data extension modes
- Colorkey processing
- Premultiplied data formats
- Global alpha and pixel alpha
- 3D graphics (side-by-side, top-and-bottom, and frame packing)
- GDC\_GP1
  - Variable input/output resolution, 32 x 32 at the minimum and 720 x 576 at the maximum
  - 8-order 8-phase horizontal scaling and 4-order 16-phase vertical scaling
  - CSC and adjustment of luminance, contrast, hue, and saturation

## 10.2 HDMI TX

### 10.2.1 Overview

The HDMI TX interface supports the HDMI 1.4 protocol. It transfers digital audio/video data in a simple, low-cost, but high-performance mode, bringing customers an omni-directional digital experience.

### 10.2.2 Function Description

#### Logic Block Diagram

[Figure 10-1](#) shows the logic block diagram of the HDMI TX interface.

**Figure 10-1** Logic block diagram of the HDMI TX interface

## Typical Application

Audio/Video data is output to the HDMI connector by configuring corresponding registers over the APB interface based on the input audio/video format of the HDMI interface. [Figure 10-2](#) shows the typical application of the HDMI.

**Figure 10-2** Typical application of the HDMI



## Features

The HDMI interface has the following features:

- HDMI 1.4a, HDCP 1.4, and DVI 1.0
- DTV video formats from 480i to 4K x 2K
  - 4Kx2K\_30 Hz
  - 1080p\_60 Hz
  - 1080p\_50 Hz
  - 1080p\_30 Hz
  - 1080p\_25 Hz
  - 1080p\_24 Hz
  - 1080i\_60 Hz
  - 1080i\_50 Hz
  - 720p\_60 Hz
  - 720p\_50 Hz
  - 576p\_50 Hz
  - 480p\_60 Hz
  - 576i\_50 Hz
  - 480i\_60 Hz
- PC video formats from VGA to UXGA
  - 640 x 480\_60 Hz
  - 800 x 600\_60 Hz
  - 1024 x 768\_60 Hz
  - 1280 x 720\_60 Hz
  - 1280 x 800\_60 Hz
  - 1280 x 1024\_60 Hz
  - 1360 x 768\_60 Hz
  - 1366 x 768\_60 Hz
  - 1400 x 1050\_60 Hz
  - 1440 x 900\_60 Hz
  - 1600 x 900\_60 Hz
  - 1680 x 1050\_60 Hz
  - 1920 x 1080\_60 Hz
  - 1920 x 1200\_60 Hz
  - 2560 x 1600\_60 Hz
- 24-/30-bit RGB or YCbCr 4:4:4 data format
- 16-/24-bit YCbCr 4:2:2 data format
- Four I<sup>2</sup>S interfaces to transfer audio data from a maximum of eight channels
- One SPDIF interface to allow maximum 192 kHz audio transmission
- HDCP encryption for transferring protected audio/video data
- I<sup>2</sup>C master interface for DDC
- HDMI 3D functions



- 1080p@60 Hz side-by-side (half) mode
- 1080p@60 Hz top-and-bottom mode
- 1080p@60 Hz frame packing mode

### 10.2.3 Operating Modes

#### Clock Configuration

If the HDMI TX interface is not used, you can disable its clocks to reduce power consumption.

- To disable all HDMI TX clocks, write 0 to PERI\_CRG67 bit[5:0].
- To enable all HDMI TX clocks, write 1 to PERI\_CRG67 bit[5:0].

The HDMI TX clocks are enabled by default.

#### Reset Deassertion

To reset the HDMI TX interface, write 1 to PERI\_CRG67 bit[9]. If you want to use the HDMI TX interface, deassert the reset by writing 0 to PERI\_CRG67 bit[9]. The HDMI interface is not reset during power-on.

#### Low-Power Mode

When the HDMI TX interface is not used, you can set it to low-power mode to reduce power consumption. The process is as follows:

- Step 1** Write 0 to RG\_TX\_EN bit[0] (0xf8ce1804) to disable the PHY output and enable the PHY to enter the low-power mode.
- Step 2** Write 0 to DPD bit[2] (0xf8ce04f4) to enable the HDMI TX controller to enter the low-power mode.

**----End**

When you want to use the HDMI TX interface, wake it up from the low-power mode by performing the following steps:

- Step 1** Write 1 to DPD bit[2] (0xf8ce04f4) to enable the HDMI TX controller to enter normal mode.
- Step 2** Write 1 to RG\_TX\_EN bit[0] (0xf8ce1804) to enable the PHY to enter normal mode.

**----End**

## 10.3 AIAO

### 10.3.1 Overview

The audio input and audio output (AIAO) module stores data into the memory based on the required interface timings (I<sup>2</sup>S/PCM), or transmits audio data to external components over the I<sup>2</sup>S/PCM/SPDIF interface.



## 10.3.2 Function Description

### Basic Features

The AI module has the following features:

- 8 kHz to 192 kHz sampling rate
- 8-/16-/24-bit sampling precision
- I<sup>2</sup>S/PCM input
- Configurable PCM data time slot
- 4-wire I<sup>2</sup>S parallel inputs
- Track mode

The AO module has the following features:

- 8 kHz to 192 kHz sampling rate
- 8-/16-/24-bit sampling precision
- I<sup>2</sup>S/PCM output
- Configurable PCM data time slot
- 4-wire I<sup>2</sup>S outputs
- SPDIF digital output
- Track mode
- 4-wire I<sup>2</sup>S 7.1 audio channel outputs
- Support for operations including mute, unmute, pause, and resume
- Transparent transmission

### Logic Block Diagram

[Figure 10-3](#) shows the logic block diagram of the AIAO module.

The AI module receives audio signals, processes the received signals in I<sup>2</sup>S or PCM mode, and then stores the signals to the DDR. The AO module processes data read from the DDR (processes the volume, fade-out, and track mode) and outputs the data in the I<sup>2</sup>S, PCM, or SPDIF format.

Figure 10-3 Logic block diagram of AIAO



## Typical Application

Figure 10-4 shows the typical application of the AIAO module.

**Figure 10-4** Typical application of the AIAO module





# Contents

|                                  |             |
|----------------------------------|-------------|
| <b>11 Peripherals.....</b>       | <b>11-1</b> |
| 11.1 GPIO .....                  | 11-1        |
| 11.1.1 Overview .....            | 11-1        |
| 11.1.2 Features .....            | 11-1        |
| 11.1.3 Function Description..... | 11-2        |
| 11.1.4 Operating Mode .....      | 11-2        |
| 11.1.5 Register Summary.....     | 11-3        |
| 11.1.6 Register Description..... | 11-4        |
| 11.2 UART .....                  | 11-9        |
| 11.2.1 Overview .....            | 11-9        |
| 11.2.2 Features .....            | 11-9        |
| 11.2.3 Function Description..... | 11-10       |
| 11.2.4 Operating Mode .....      | 11-11       |
| 11.2.5 Register Summary.....     | 11-13       |
| 11.2.6 Register Description..... | 11-14       |
| 11.3 I <sup>2</sup> C .....      | 11-26       |
| 11.3.1 Overview .....            | 11-26       |
| 11.3.2 Function Description..... | 11-26       |
| 11.3.3 Operating Mode .....      | 11-26       |
| 11.3.4 Register Summary.....     | 11-29       |
| 11.3.5 Register Description..... | 11-29       |
| 11.4 IR.....                     | 11-37       |
| 11.4.1 Overview .....            | 11-37       |
| 11.4.2 Features .....            | 11-37       |
| 11.4.3 Function Description..... | 11-37       |
| 11.4.4 Operating Mode .....      | 11-45       |
| 11.4.5 Register Summary.....     | 11-48       |
| 11.4.6 Register Description..... | 11-49       |
| 11.5 LED .....                   | 11-64       |
| 11.5.1 Overview .....            | 11-64       |
| 11.5.2 Function Description..... | 11-64       |
| 11.5.3 Operating Mode .....      | 11-65       |



|                                                               |        |
|---------------------------------------------------------------|--------|
| 11.5.4 Interface Signals.....                                 | 11-66  |
| 11.5.5 Register Summary.....                                  | 11-66  |
| 11.5.6 Register Description.....                              | 11-67  |
| 11.6 SPI.....                                                 | 11-76  |
| 11.6.1 Overview.....                                          | 11-76  |
| 11.6.2 Features .....                                         | 11-76  |
| 11.6.3 Function Description.....                              | 11-76  |
| 11.6.4 Peripheral Bus Timings .....                           | 11-77  |
| 11.6.5 Operating Mode .....                                   | 11-84  |
| 11.6.6 Register Summary.....                                  | 11-86  |
| 11.6.7 Register Description.....                              | 11-87  |
| 11.7 USB 2.0 .....                                            | 11-94  |
| 11.7.1 Overview.....                                          | 11-94  |
| 11.7.2 Function Description.....                              | 11-95  |
| 11.7.3 Operating Mode .....                                   | 11-97  |
| 11.7.4 Summary of USB Host Register .....                     | 11-99  |
| 11.7.5 Description of USB Host Registers.....                 | 11-99  |
| 11.7.6 Offset Address Variables for USB Device Registers..... | 11-105 |
| 11.7.7 Summary of USB Device Registers.....                   | 11-105 |
| 11.7.8 Description of USB Device Registers.....               | 11-107 |
| 11.8 USB 3.0 Host.....                                        | 11-178 |
| 11.8.1 Overview .....                                         | 11-178 |
| 11.8.2 Function Description.....                              | 11-179 |
| 11.8.3 Operating Mode .....                                   | 11-181 |
| 11.8.4 Register Variables.....                                | 11-181 |
| 11.8.5 Register Summary.....                                  | 11-182 |
| 11.8.6 Register Description.....                              | 11-183 |
| 11.9 SCI.....                                                 | 11-216 |
| 11.9.1 Overview .....                                         | 11-216 |
| 11.9.2 Features .....                                         | 11-216 |
| 11.9.3 Function Description.....                              | 11-216 |
| 11.9.4 Operating Mode .....                                   | 11-220 |
| 11.9.5 Register Summary.....                                  | 11-221 |
| 11.9.6 Register Description.....                              | 11-222 |



# Figures

|                                                                                                                                |       |
|--------------------------------------------------------------------------------------------------------------------------------|-------|
| <b>Figure 11-1</b> Typical application block diagram of the UART .....                                                         | 11-10 |
| <b>Figure 11-2</b> UART frame format .....                                                                                     | 11-11 |
| <b>Figure 11-3</b> Process for transmitting data by using the I <sup>2</sup> C master.....                                     | 11-27 |
| <b>Figure 11-4</b> Process for receiving data by using the I <sup>2</sup> C master .....                                       | 11-28 |
| <b>Figure 11-5</b> Functional block diagram of the IR module.....                                                              | 11-37 |
| <b>Figure 11-6</b> Format for transmitting a single frame in NEC with simple repeat code format .....                          | 11-40 |
| <b>Figure 11-7</b> Format for transmitting consecutive frames in NEC with simple repeat code format by holding a key down..... | 11-40 |
| <b>Figure 11-8</b> Definitions of bit 0 and bit 1 of the NEC with simple repeat code .....                                     | 11-40 |
| <b>Figure 11-9</b> Format for transmitting an NEC with simple repeat code.....                                                 | 11-41 |
| <b>Figure 11-10</b> Format for transmitting consecutive NEC with simple repeat codes .....                                     | 11-41 |
| <b>Figure 11-11</b> Format for transmitting a single frame in NEC with full repeat code format.....                            | 11-41 |
| <b>Figure 11-12</b> Format for transmitting consecutive frames in NEC with full repeat code format by holding a key down.....  | 11-42 |
| <b>Figure 11-13</b> Definitions of bit 0 and bit 1 of the NEC with full repeat code .....                                      | 11-42 |
| <b>Figure 11-14</b> Format for transmitting a single NEC with full repeat code .....                                           | 11-42 |
| <b>Figure 11-15</b> Format for transmitting a single frame in TC9012 code format.....                                          | 11-43 |
| <b>Figure 11-16</b> Format for transmitting consecutive frames in TC9012 code format by holding a key down ..                  | 11-43 |
| <b>Figure 11-17</b> Definitions of bit 0 and bit 1 of the TC9012 code.....                                                     | 11-43 |
| <b>Figure 11-18</b> Format for transmitting a single TC9012 code .....                                                         | 11-43 |
| <b>Figure 11-19</b> Format for transmitting consecutive TC9012 codes when C0 is 1.....                                         | 11-44 |
| <b>Figure 11-20</b> Format for transmitting consecutive TC9012 codes when C0 is 0.....                                         | 11-44 |
| <b>Figure 11-21</b> Format for transmitting a single frame in SONY code format.....                                            | 11-44 |
| <b>Figure 11-22</b> Format for transmitting consecutive frames in SONY code format by holding a key down ....                  | 11-45 |
| <b>Figure 11-23</b> Definitions of bit 0 and bit 1 of the SONY code .....                                                      | 11-45 |
| <b>Figure 11-24</b> Process for initializing the IR module.....                                                                | 11-46 |
| <b>Figure 11-25</b> Process for reading the decoded data .....                                                                 | 11-47 |



|                                                                                                           |        |
|-----------------------------------------------------------------------------------------------------------|--------|
| <b>Figure 11-26</b> Output timing of the LED module .....                                                 | 11-65  |
| <b>Figure 11-27</b> SPI connected to a single slave .....                                                 | 11-77  |
| <b>Figure 11-28</b> Format of a single SPI frame (SPO = 0, SPH = 0).....                                  | 11-77  |
| <b>Figure 11-29</b> Format of consecutive SPI frames (SPO = 0, SPH = 0).....                              | 11-78  |
| <b>Figure 11-30</b> Format of a single SPI frame (SPO = 0, SPH = 1).....                                  | 11-78  |
| <b>Figure 11-31</b> Format of consecutive SPI frames (SPO = 0, SPH = 1).....                              | 11-79  |
| <b>Figure 11-32</b> Format of a single SPI frame (SPO = 1, SPH = 0).....                                  | 11-79  |
| <b>Figure 11-33</b> Format of consecutive SPI frames (SPO = 1, SPH = 0).....                              | 11-80  |
| <b>Figure 11-34</b> SPI single frame format (SPO = 1, SPH = 1).....                                       | 11-80  |
| <b>Figure 11-35</b> SPI consecutive frame format (SPO = 1, SPH = 1) .....                                 | 11-81  |
| <b>Figure 11-36</b> Format of a single frame for the TI synchronous serial interface .....                | 11-81  |
| <b>Figure 11-37</b> Format of consecutive frames for the TI synchronous serial interface .....            | 11-82  |
| <b>Figure 11-38</b> Format of a single frame for the national semiconductor microwire interface .....     | 11-82  |
| <b>Figure 11-39</b> Format of consecutive frames for the national semiconductor microwire interface ..... | 11-83  |
| <b>Figure 11-40</b> SPI timing .....                                                                      | 11-84  |
| <b>Figure 11-41</b> Logic block diagram of the USB 2.0 host controller .....                              | 11-95  |
| <b>Figure 11-42</b> Logical block diagram of the USB 2.0 device controller.....                           | 11-96  |
| <b>Figure 11-43</b> Reference design of the USB 2.0 module .....                                          | 11-96  |
| <b>Figure 11-44</b> Logic block diagram of the USB 3.0 host.....                                          | 11-179 |
| <b>Figure 11-45</b> USB 3.0 host reference design .....                                                   | 11-180 |
| <b>Figure 11-46</b> Typical application circuit diagram of the SCI.....                                   | 11-217 |
| <b>Figure 11-47</b> Timing for resetting the smart card .....                                             | 11-218 |
| <b>Figure 11-48</b> Timing for releasing the smart card .....                                             | 11-218 |
| <b>Figure 11-49</b> SCI timing for soft-resetting the smart card.....                                     | 11-219 |
| <b>Figure 11-50</b> Character transfer structure supported by the SCI .....                               | 11-219 |



# Tables

|                                                                                                 |        |
|-------------------------------------------------------------------------------------------------|--------|
| <b>Table 11-1</b> Base addresses for the seven groups of GPIO registers .....                   | 11-3   |
| <b>Table 11-2</b> Summary of GPIO registers.....                                                | 11-4   |
| <b>Table 11-3</b> Summary of UART registers .....                                               | 11-13  |
| <b>Table 11-4</b> Summary of I <sup>2</sup> C registers.....                                    | 11-29  |
| <b>Table 11-5</b> Code formats of the received infrared data (NEC with simple repeat code)..... | 11-38  |
| <b>Table 11-6</b> Code formats of the received infrared data (NEC with full repeat code).....   | 11-38  |
| <b>Table 11-7</b> Code formats of the received infrared data (TC9012 code and SONY code).....   | 11-39  |
| <b>Table 11-8</b> Summary of IR registers (base address: 0xF8001000) .....                      | 11-48  |
| <b>Table 11-9</b> LED interface signals (8 x 1 matrix keypad scanning) .....                    | 11-66  |
| <b>Table 11-10</b> Summary of LED registers (base address: 0xF800_3000).....                    | 11-66  |
| <b>Table 11-11</b> SPI timing parameters .....                                                  | 11-84  |
| <b>Table 11-12</b> Summary of SPI registers .....                                               | 11-86  |
| <b>Table 11-13</b> Summary of USB host registers.....                                           | 11-99  |
| <b>Table 11-14</b> Register variables.....                                                      | 11-105 |
| <b>Table 11-15</b> Summary of USB device registers (base address: 0xF98C0000).....              | 11-105 |
| <b>Table 11-16</b> Variables in the offset addresses for USB 3.0 registers.....                 | 11-181 |
| <b>Table 11-17</b> Summary of USB 3.0 host registers (base address: 0xF98A_0000) .....          | 11-182 |
| <b>Table 11-18</b> Summary of SCI registers (base address: 0xF8B1_8000) .....                   | 11-221 |



# 11 Peripherals

## 11.1 GPIO

### 11.1.1 Overview

Hi3796M V100 supports seven groups of GPIO pins, and each group provides eight programmable input/output pins. Each GPIO pin can be configured as an input or output. These pins are used to generate output signals or capture input signals for specific applications. As an input, each GPIO pin can act as an interrupt source; as an output, each GPIO pin can be separately set to 0 or 1.



#### CAUTION

For details about the number of GPIO pins, multiplexing relationship between GPIO pins and other pins, and the control modes, see the "Package and Pinout" section in the *Hi3796M V100 Intelligent Network Terminal Media Processor Hardware User Guide*.

### 11.1.2 Features

The GPIO module has the following features:

- Each GPIO pin can be set to input or output.
  - When a GPIO pin acts as an input pin, it can be used as the interrupt source. Each GPIO pin supports independent interrupt control.
  - When a GPIO pin acts as an output pin, it can be separately cleared or set to 1.
- The GPIO interrupts are controlled by seven registers (such as [GPIO\\_IS](#)). These registers are used to specify the interrupt source, interrupt edge (falling edge or rising edge), and interrupt trigger modes (level-sensitive mode or edge-sensitive mode). For details about the corresponding interrupt registers of the GPIO, see section 3.6 "Interrupt System".
  - When multiple interrupts are generated at the same time, these interrupts are combined as one interrupt and then reported. For details about the GPIO interrupt mapping, see section 3.6 "Interrupt System".
  - The [GPIO\\_IS](#), [GPIO\\_IBE](#), and [GPIO\\_IEN](#) registers determine the features of the interrupt source and the interrupt trigger type.



[GPIO\\_RIS](#) and [GPIO\\_MIS](#) are used to read the raw interrupt status and masked interrupt status respectively. [GPIO\\_IE](#) controls the final report status of each interrupt. In addition, [GPIO\\_IC](#) is provided for clearing the interrupt status.

### 11.1.3 Function Description

Each GPIO pin group contains eight programmable I/O pins. Each GPIO pin can be configured as an input or output. These pins are used to collect input signals or generate output signals for specific purposes.

The GPIO module can generate maskable interrupts based on the level or transition value. The general purpose input output interrupt (GPIOINTR) signal provides an indicator to the interrupt controller, indicating that an interrupt is generated.

### 11.1.4 Operating Mode

#### Interface Reset

During POR, all registers are cleared, and therefore the pins work as input pins by default.

When the reset signal is valid, the GPIO status is as follows:

- The interrupt becomes invalid after the corresponding bit of [GPIO\\_IE](#) is cleared.
- All registers are cleared.
- All pins are configured as inputs.
- All raw interrupt registers are cleared.
- The interrupt trigger mode is configured as edge-sensitive mode.

#### GPIO

Each pin can be configured as input or output. To configure a GPIO pin, perform the following steps:

**Step 1** Configure the corresponding bit of the GPIO pin to enable required GPIO pin functions. For details, see the "Package and Pinout" section in the *Hi3796M V100 Intelligent Network Terminal Media Processor Hardware User Guide*.

**Step 2** Set the GPIO pin as input or output by configuring [GPIO\\_DIR](#).

- If the GPIO pin is used as input, external signals are transmitted through the GPIO pin. In this case, the values of input signals can be obtained by reading [GPIO\\_DATA](#).  
Note: The input signals are also transmitted to the pins that are multiplexed with the GPIO pin.
- If the GPIO pin is used as output, values are written to [GPIO\\_DATA](#) and then output through the GPIO pin.  
Note: If the GPIO interrupt function is enabled, an interrupt is generated when the output signal meets the triggering condition.

----End

#### Interrupt Operation

To generate an interrupt but not a pseudo interrupt, perform the following steps:



- Step 1** Select the edge-sensitive mode or level-sensitive mode by configuring [GPIO\\_IS](#).
- Step 2** Select the falling-/rising-edge-sensitive mode or high-/low-level-sensitive mode by configuring [GPIO\\_IEV](#).
- Step 3** If the edge-sensitive mode is selected, select single-edge-sensitive mode or dual-edge-sensitive mode by configuring [GPIO\\_IBE](#).
- Ensure that the GPIO data lines are stable during preceding operations.
- Step 4** Write 0xFF to [GPIO\\_IC](#) to clear the interrupt.
- Step 5** Set [GPIO\\_IE](#) to 1 to enable the interrupt.
- End

The GPIO interrupts are controlled by seven registers. When one or more GPIO pins generate interrupts, a combined interrupt is output to the interrupt controller. The following are the differences between the edge-sensitive mode and the level-sensitive mode:

- Edge-sensitive mode: Software must clear the interrupt to enable superior interrupts.
- Level-sensitive mode: The external interrupt source should keep the level until the processor identifies the interrupt.

## 11.1.5 Register Summary

[Table 11-1](#) lists the base addresses for the seven groups of GPIO registers.

**Table 11-1** Base addresses for the seven groups of GPIO registers

| Register | Base Address |
|----------|--------------|
| GPIO0    | 0xF8B2_0000  |
| GPIO1    | 0xF8B2_1000  |
| GPIO2    | 0xF8B2_2000  |
| GPIO3    | 0xF8B2_3000  |
| GPIO4    | 0xF8B2_4000  |
| GPIO5    | 0xF800_4000  |
| GPIO6    | 0xF8B2_6000  |

The GPIO groups in table [Table 11-1](#) have the same registers.

 **NOTE**

- The address for the register corresponding to  $\text{GPIO}_n$  consists of the  $\text{GPIO}_n$  base address and register offset address.
- $n$  ranges from 0 to 6.

[Table 11-2](#) describes GPIO registers.



**Table 11-2** Summary of GPIO registers

| Offset Address | Register      | Description                           | Page                 |
|----------------|---------------|---------------------------------------|----------------------|
| 0x000–0x3FC    | GPIO_DATA     | GPIO data register                    | <a href="#">11-4</a> |
| 0x400          | GPIO_DIR      | GPIO direction control register       | <a href="#">11-5</a> |
| 0x404          | GPIO_IS       | GPIO interrupt trigger register       | <a href="#">11-5</a> |
| 0x408          | GPIO_IBE      | GPIO interrupt edge control register  | <a href="#">11-6</a> |
| 0x40C          | GPIO_IEV      | GPIO interrupt trigger event register | <a href="#">11-6</a> |
| 0x410          | GPIO_IE       | GPIO interrupt mask register          | <a href="#">11-7</a> |
| 0x414          | GPIO_RIS      | GPIO raw interrupt status register    | <a href="#">11-7</a> |
| 0x418          | GPIO_MIS      | GPIO masked interrupt status register | <a href="#">11-8</a> |
| 0x41C          | GPIO_IC       | GPIO interrupt clear register         | <a href="#">11-8</a> |
| 0x420          | GPIO_RESERVED | Reserved GPIO register                | <a href="#">11-9</a> |

## 11.1.6 Register Description

### GPIO\_DATA

GPIO\_DATA is a GPIO data register. It is used to buffer the input or output data.

When the corresponding bit of [GPIO\\_DIR](#) is configured as output, the values written to GPIO\_DATA are output to the corresponding pin (ensure that the configuration of pin multiplexing is correct). If the bit is configured as input, the value of the corresponding input pin is read.



#### CAUTION

When the corresponding bits of [GPIO\\_DIR](#) are set to inputs, the pin values are returned if the read operation is valid. When the corresponding bits are set to outputs, the written values are returned if the read operation is valid.

The GPIO\_DATA register masks the read and write operations on bits by using PADDR[9:2]. This register corresponds to 256 address spaces. PADDR[9:2] correspond to GPIO\_DATA[7:0]. When a PADDR bit is high, the corresponding bit in GPIO\_DATA can be read or written; when the corresponding bit is low, the read or write operation is not allowed. For example:

- If the address is 0x3FC (0b11\_1111\_1100), operations on all the eight bits of GPIO\_DATA[7:0] are valid.



- If the address is 0x200 (0b10\_0000\_0000), the operation on only GPIO\_DATA[7] is valid.

|       | Offset Address |           |                                                                                                                                                                                             |   | Register Name |   |   |   | Total Reset Value |  |  |  |
|-------|----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------|---|---|---|-------------------|--|--|--|
|       | 0x000–0x3FC    |           |                                                                                                                                                                                             |   | GPIO_DATA     |   |   |   | 0x00              |  |  |  |
| Bit   | 7              | 6         | 5                                                                                                                                                                                           | 4 | 3             | 2 | 1 | 0 |                   |  |  |  |
| Name  | gpio_data      |           |                                                                                                                                                                                             |   |               |   |   |   |                   |  |  |  |
| Reset | 0              | 0         | 0                                                                                                                                                                                           | 0 | 0             | 0 | 0 | 0 |                   |  |  |  |
| Bits  | Access         | Name      | Description                                                                                                                                                                                 |   |               |   |   |   |                   |  |  |  |
| [7:0] | RW             | gpio_data | GPIO input data when the GPIO is configured as input or GPIO output data when the GPIO is configured as output<br>Each bit can be separately controlled. This register works with GPIO_DIR. |   |               |   |   |   |                   |  |  |  |

## GPIO\_DIR

GPIO\_DIR is a GPIO direction control register. It is used to configure the direction of each GPIO pin.

|       | Offset Address |          |                                                                                                                                                 |   | Register Name |   |   |   | Total Reset Value |  |  |  |
|-------|----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------|---|---|---|-------------------|--|--|--|
|       | 0x400          |          |                                                                                                                                                 |   | GPIO_DIR      |   |   |   | 0x00              |  |  |  |
| Bit   | 7              | 6        | 5                                                                                                                                               | 4 | 3             | 2 | 1 | 0 |                   |  |  |  |
| Name  | gpio_dir       |          |                                                                                                                                                 |   |               |   |   |   |                   |  |  |  |
| Reset | 0              | 0        | 0                                                                                                                                               | 0 | 0             | 0 | 0 | 0 |                   |  |  |  |
| Bits  | Access         | Name     | Description                                                                                                                                     |   |               |   |   |   |                   |  |  |  |
| [7:0] | RW             | gpio_dir | GPIO direction control. Bit[7:0] correspond to GPIO_DATA bit[7:0] respectively. Each bit can be separately controlled.<br>0: input<br>1: output |   |               |   |   |   |                   |  |  |  |

## GPIO\_IS

GPIO\_IS is a GPIO interrupt trigger mode register. It is used to configure the interrupt trigger mode.



| Offset Address |         |         |                                                                                                                                                                                  |   |   |   |   | Register Name | Total Reset Value |
|----------------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| 0x404          |         |         |                                                                                                                                                                                  |   |   |   |   | GPIO_IS       | 0x00              |
| Bit            | 7       | 6       | 5                                                                                                                                                                                | 4 | 3 | 2 | 1 | 0             |                   |
| Name           | gpio_is |         |                                                                                                                                                                                  |   |   |   |   |               |                   |
| Reset          | 0       | 0       | 0                                                                                                                                                                                | 0 | 0 | 0 | 0 | 0             |                   |
| Bits           | Access  | Name    | Description                                                                                                                                                                      |   |   |   |   |               |                   |
| [7:0]          | RW      | gpio_is | GPIO interrupt trigger mode. Bit[7:0] correspond to GPIO_DATA bit[7:0] respectively. Each bit can be separately controlled.<br>0: edge-sensitive mode<br>1: level-sensitive mode |   |   |   |   |               |                   |

## GPIO\_IBE

GPIO\_IBE is a GPIO interrupt edge control register. It is used to configure the edge trigger mode of each GPIO pin.

| Offset Address |          |          |                                                                                                                                                                                                                                                                                                      |   |   |   |   | Register Name | Total Reset Value |
|----------------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| 0x408          |          |          |                                                                                                                                                                                                                                                                                                      |   |   |   |   | GPIO_IBE      | 0x00              |
| Bit            | 7        | 6        | 5                                                                                                                                                                                                                                                                                                    | 4 | 3 | 2 | 1 | 0             |                   |
| Name           | gpio_ibe |          |                                                                                                                                                                                                                                                                                                      |   |   |   |   |               |                   |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                                    | 0 | 0 | 0 | 0 | 0             |                   |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                          |   |   |   |   |               |                   |
| [7:0]          | RW       | gpio_ibe | GPIO interrupt edge control. Bit[7:0] correspond to GPIO_DATA[7:0] respectively. Each bit can be separately controlled.<br>0: single-edge-sensitive mode. <a href="#">GPIO_IEV</a> controls whether the interrupt is rising-edge-sensitive or falling-edge-sensitive.<br>1: dual-edge-sensitive mode |   |   |   |   |               |                   |

## GPIO\_IEV

GPIO\_IEV is a GPIO interrupt trigger event register. It is used to configure the interrupt trigger event of a GPIO pin.



| Offset Address |          |          |                                                                                                                                                                                                                                                                                    |   |   |   |   | Register Name | Total Reset Value |
|----------------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| Bit            | 0x40C    |          |                                                                                                                                                                                                                                                                                    |   |   |   |   | GPIO_IEV      | 0x00              |
| Name           | gpio_iev |          |                                                                                                                                                                                                                                                                                    |   |   |   |   |               |                   |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                  | 0 | 0 | 0 | 0 | 0             | 0                 |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                        |   |   |   |   |               |                   |
| [7:0]          | RW       | gpio_iev | GPIO interrupt trigger event. Bit[7:0] correspond to <a href="#">GPIO_DATA</a> bit[7:0] respectively. Each bit can be separately controlled.<br>0: The interrupt is triggered by the falling edge or low level.<br>1: The interrupt is triggered by the rising edge or high level. |   |   |   |   |               |                   |

## GPIO\_IE

GPIO\_IE is a GPIO interrupt mask register. It is used to mask GPIO interrupts.

| Offset Address |         |         |                                                                                                                                                                   |   |   |   |   | Register Name | Total Reset Value |
|----------------|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| Bit            | 0x410   |         |                                                                                                                                                                   |   |   |   |   | GPIO_IE       | 0x00              |
| Name           | gpio_ie |         |                                                                                                                                                                   |   |   |   |   |               |                   |
| Reset          | 0       | 0       | 0                                                                                                                                                                 | 0 | 0 | 0 | 0 | 0             | 0                 |
| Bits           | Access  | Name    | Description                                                                                                                                                       |   |   |   |   |               |                   |
| [7:0]          | RW      | gpio_ie | GPIO interrupt mask. Bit[7:0] correspond to <a href="#">GPIO_DATA</a> bit[7:0] respectively. Each bit can be separately controlled.<br>0: masked<br>1: not masked |   |   |   |   |               |                   |

## GPIO\_RIS

GPIO\_RIS is a GPIO raw interrupt status register. It is used to query the raw interrupt status of each GPIO pin.



| Offset Address |          |          |                                                                                                                                                                                                                                                                                                   |   |   |   |   | Register Name | Total Reset Value |
|----------------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| 0x414          |          |          |                                                                                                                                                                                                                                                                                                   |   |   |   |   | GPIO_RIS      | 0x00              |
| Bit            | 7        | 6        | 5                                                                                                                                                                                                                                                                                                 | 4 | 3 | 2 | 1 | 0             |                   |
| Name           | gpio_ris |          |                                                                                                                                                                                                                                                                                                   |   |   |   |   |               |                   |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                                 | 0 | 0 | 0 | 0 | 0             |                   |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                       |   |   |   |   |               |                   |
| [7:0]          | RO       | gpio_ris | GPIO raw interrupt status. Bit[7:0] correspond to <a href="#">GPIO_DATA</a> bit[7:0] respectively, indicating the unmasked interrupt status. This status is not under the mask control of the <a href="#">GPIO_IE</a> register.<br>0: No interrupt is generated.<br>1: An interrupt is generated. |   |   |   |   |               |                   |

## GPIO\_MIS

GPIO\_MIS is a GPIO masked interrupt status register. It is used to query the masked interrupt status of each GPIO pin.

| Offset Address |          |          |                                                                                                                                                                                                                                                                                               |   |   |   |   | Register Name | Total Reset Value |
|----------------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| 0x418          |          |          |                                                                                                                                                                                                                                                                                               |   |   |   |   | GPIO_MIS      | 0x00              |
| Bit            | 7        | 6        | 5                                                                                                                                                                                                                                                                                             | 4 | 3 | 2 | 1 | 0             |                   |
| Name           | gpio_mis |          |                                                                                                                                                                                                                                                                                               |   |   |   |   |               |                   |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                             | 0 | 0 | 0 | 0 | 0             |                   |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                   |   |   |   |   |               |                   |
| [7:0]          | RO       | gpio_mis | GPIO masked interrupt status. Bit[7:0] correspond to <a href="#">GPIO_DATA</a> bit[7:0] respectively, indicating the masked interrupt status. This status can be masked and controlled by the <a href="#">GPIO_IE</a> register.<br>0: The interrupt is invalid.<br>1: The interrupt is valid. |   |   |   |   |               |                   |

## GPIO\_IC

GPIO\_IC is a GPIO interrupt clear register. It is used to clear the [GPIO\\_RIS](#) and [GPIO\\_MIS](#) registers and interrupts generated by GPIO pins.



| Offset Address |         |         |                                                                                                                                                                      |   |   |   |   | Register Name | Total Reset Value |
|----------------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|---------------|-------------------|
| Bit            | 0x41C   |         |                                                                                                                                                                      |   |   |   |   | GPIO_IC       | 0x00              |
| Name           | gpio_ic |         |                                                                                                                                                                      |   |   |   |   |               |                   |
| Reset          | 0       | 0       | 0                                                                                                                                                                    | 0 | 0 | 0 | 0 | 0             | 0                 |
| Bits           | Access  | Name    | Description                                                                                                                                                          |   |   |   |   |               |                   |
| [7:0]          | WC      | gpio_ic | GPIO interrupt clear. Bit[7:0] correspond to <a href="#">GPIO_DATA</a> bit[7:0] respectively. Each bit can be separately controlled.<br>0: not cleared<br>1: cleared |   |   |   |   |               |                   |

## GPIO\_RESERVED

GPIO\_RESERVED is a reserved GPIO register. It must be configured as required.

| Offset Address |          |          |                                 |   |   |   |   | Register Name | Total Reset Value |
|----------------|----------|----------|---------------------------------|---|---|---|---|---------------|-------------------|
| Bit            | 0x420    |          |                                 |   |   |   |   | GPIO_RESERVED | 0x00              |
| Name           | reserved |          |                                 |   |   |   |   |               |                   |
| Reset          | 0        | 0        | 0                               | 0 | 0 | 0 | 0 | 0             | 0                 |
| Bits           | Access   | Name     | Description                     |   |   |   |   |               |                   |
| [7:0]          | RW       | reserved | This field must be set to 0x00. |   |   |   |   |               |                   |

## 11.2 UART

### 11.2.1 Overview

The UART interface is an asynchronous serial communication interface. The UART is mainly used to interconnect with the UART of an external chip so that the two chips can communicate with each other.

Hi3796M V100 provides three UART units. UART 0 and UART 1 support the 2-wire mode, and UART 2 supports the 4-wire mode.

### 11.2.2 Features

The UART module has the following features:

- Supports a 16x8-bit TX FIFO and a 16x12-bit RX FIFO.



- Allows the widths of the data bit and stop bit to be programmed. The width of the data bit can be set to 5 bits, 6 bits, 7 bits, or 8 bits and that of the stop bit can be set to 1 bit or 2 bits by programming.
- Supports parity check or no check.
- Allows the transfer rate to be programmed.
- Supports RX FIFO interrupts, TX FIFO interrupts, RX timeout interrupts, and error interrupts.
- Supports querying of the status of raw and masked interrupts.
- Allows the UART or the RX/TX function of the UART to be disabled by programming, reducing power consumption.
- Allows the UART clock to be disabled to reduce power consumption.

### 11.2.3 Function Description

#### Application Block Diagram

Figure 11-1 shows the typical application block diagram the UART.

**Figure 11-1** Typical application block diagram of the UART



The UART serves as an asynchronous bidirectional serial bus. It provides a simple and effective data transfer mode that requires only two data lines.

#### Function Implementation

One frame transfer of the UART involves the start signal, data signal, parity bit, and stop signal, as shown in Figure 11-2. The data frame is output from the TxD port of one UART and then is input to the RxD port of the other UART.



Figure 11-2 UART frame format



The following describes the start signal, data signal, parity bit, and stop signal:

- Start signal (start bit)

It is the start flag of a data frame. According to the UART protocol, a low level of the TXD signal indicates the start of a data frame. When the UART does not transmit data, the level must remain high.

- Data signal (data bit)

The data bit width can be set to 5 bits, 6 bits, 7 bits, or 8 bits based on the actual application scenario.

- Parity bit

It is a 1-bit error correction signal. The UART parity bit can be an odd parity bit, even parity bit, or stick parity bit. The parity bit can be enabled or disabled. For details, see the description of [UART\\_LCR\\_H](#).

- Stop signal (stop bit)

It is the stop bit of a data frame. The stop bit width can be set to 1 bit or 2 bits. The high level of TXD indicates the end of a data frame.

## 11.2.4 Operating Mode

### 11.2.4.1 Configuring the Baud Rate

The operating baud rate of the UART can be set by configuring [UART\\_IBRD](#) and [UART\\_FBRD](#). The baud rate is calculated as follows:

$$\text{Current baud rate} = \text{Frequency of the UART reference clock} / (16 \times \text{Clock divider})$$

The clock divider consists of the integer part and the decimal part that correspond to [UART\\_IBRD](#) and [UART\\_FBRD](#) respectively.

For example, if the frequency of the internal bus clock is 60 MHz, [UART\\_IBRD](#) is set to 0x1E, and [UART\\_FBRD](#) is set to 0x00, the current baud rate is 0.125 Mbit/s ( $60/(16 \times 30)$ ).

The typical UART baud rates are 9600 bit/s, 14,400 bit/s, 19,200 bit/s, 38,400 bit/s, 57,600 bit/s, 76,800 bit/s, 115,200 bit/s, 230,400 bit/s, and 460,800 bit/s.

The following examples illustrate how to calculate the clock divider and how to configure the clock divider register.

If the required baud rate is 230,400 bit/s and the frequency of [UARTCLK](#) is 100 MHz, the clock divider is calculated as follows: Clock divider =  $(100 \times 10^6) / (16 \times 230,400) = 27.1267$ . Therefore, IBRD (the integer part) is 27, and FBRD (the decimal part) is 0.1267.

Calculate the value of 6-bit [UART\\_FBRD](#) by using the following formula: m = integer ( $FBRD \times 2^n + 0.5$ ). n indicates the width of [UART\\_FBRD](#). According to the preceding results,



$m = \text{integer} (0.1267 \times 2^6 + 0.5) = 8$ . Then set **UART\_IBRD** to 0x001B and **UART\_FBRD** to 0x08.

If the decimal part of the clock divider is set to 8, the actual divisor is 27.125 ( $27 + 8/64$ ), the baud rate and error rate are calculated as follows:

- Baud rate =  $(100 \times 10^6)/(16 \times 27.125) = 230,414.75$
- Error rate =  $(230,414.75 - 230,400)/230,400 \times 100 = 0.006\%$ .

The maximum error rate is 1.56% ( $1/64 \times 100$ ) when the 6-bit **UART\_FBRD** is used. If  $m$  is 1, the error rate is accumulated for more than 64 clock cycles.

#### 11.2.4.2 Soft-Resetting the UART Controller

The UART controller can be independently reset by configuring CRG registers.

- The UART1 controller can be independently soft-reset by setting **SC\_CLKGATE\_SRST\_CTRL[uart\_srst\_req]** to 1.
- The UART0 controller can be independently soft-reset by setting **PERI\_CRG26[uart0\_srst\_req]** to 1.
- The UART2 controller can be independently soft-reset by setting **PERI\_CRG26[uart2\_srst\_req]** to 1.

After reset, the configuration registers are restored to default values. Therefore, these registers must be initialized and configured again.

#### 11.2.4.3 Transmitting Data in Interrupt or Query Mode

##### Initializing the UART

The UART is initialized as follows:

- Step 1** Write 0 to **UART\_CR** bit[0] to disable the UART.
- Step 2** Write values to **UART\_IBRD** and **UART\_FBRD** to configure the transfer rate.
- Step 3** Configure **UART\_CR** and **UART\_LCR\_H** to set the UART operating mode.
- Step 4** Configure **UART\_IFLS** to set the TX and RX FIFO thresholds.
- Step 5** If the driver runs in interrupt mode, set **UART\_IMSC** to enable corresponding interrupt signals. If the driver runs in query mode, disable the generation of corresponding interrupts.
- Step 6** Write 1 to **UART\_CR** bit[0] to enable the UART.

----End

##### Transmitting Data

Data is transmitted as follows:

- Step 1** Write the data to be transmitted to **UART\_DR** to start data transmission.
- Step 2** In query mode, check the TX\_FIFO status by reading **UART\_FR[5]** if data is being consecutively transmitted. According to the TX\_FIFO status, determine whether to transmit data to TX\_FIFO. In interrupt mode, check the TX\_FIFO status by reading the corresponding interrupt status bits and then determine whether to transmit data to TX\_FIFO.



**Step 3** Check whether the UART transmits all data by reading [UART\\_FR](#) bit[7]. If [UART\\_FR](#) bit[7] is 1, data transmission is complete.

----End

## Receiving Data

Data is received as follows:

- In query mode, check the RX FIFO status by reading [UART\\_FR](#)[rxfc] during data reception, and then determine whether to read data from the RX FIFO based on its status.
- In interrupt mode, determine whether to read data from the RX FIFO based on corresponding interrupt status bits.

## 11.2.5 Register Summary

Hi3796M V100 has three UARTs. The following are the base addresses for corresponding UART registers:

- UART0: 0xF8B0\_0000
- UART1: 0xF800\_6000
- UART2: 0xF8B0\_2000

[Table 11-3](#) describes UART registers.

**Table 11-3** Summary of UART registers

| Offset Address | Register   | Description                                | Page                  |
|----------------|------------|--------------------------------------------|-----------------------|
| 0x000          | UART_DR    | UART data register                         | <a href="#">11-14</a> |
| 0x004          | UART_RSR   | RX status register or error clear register | <a href="#">11-14</a> |
| 0x018          | UART_FR    | UART flag register                         | <a href="#">11-15</a> |
| 0x024          | UART_IBRD  | Integral baud rate register                | <a href="#">11-17</a> |
| 0x028          | UART_FBRD  | Decimal baud rate register                 | <a href="#">11-17</a> |
| 0x02C          | UART_LCR_H | Transfer mode control register             | <a href="#">11-18</a> |
| 0x030          | UART_CR    | UART control register                      | <a href="#">11-19</a> |
| 0x034          | UART_IFLS  | Interrupt FIFO threshold select register   | <a href="#">11-20</a> |
| 0x038          | UART_IMSC  | Interrupt mask register                    | <a href="#">11-21</a> |
| 0x03C          | UART_RIS   | Raw interrupt status register              | <a href="#">11-22</a> |
| 0x040          | UART_MIS   | Masked interrupt status register           | <a href="#">11-23</a> |
| 0x044          | UART_ICR   | Interrupt clear register                   | <a href="#">11-24</a> |
| 0x048          | UART_DMACR | DMA control register                       | <a href="#">11-25</a> |



## 11.2.6 Register Description

### UART\_DR

UART\_DR is a UART data register that stores the received data and data to be transmitted. The RX status can be queried by reading this register.

|         |          | Offset Address |    |    |                                                                                                                                                                                                                                    | Register Name |    | Total Reset Value |      |   |   |   |   |   |   |   |  |
|---------|----------|----------------|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----|-------------------|------|---|---|---|---|---|---|---|--|
|         |          | 0x000          |    |    |                                                                                                                                                                                                                                    | UART_DR       |    | 0x0000            |      |   |   |   |   |   |   |   |  |
| Bit     | 15       | 14             | 13 | 12 | 11                                                                                                                                                                                                                                 | 10            | 9  | 8                 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name    | reserved |                |    |    | oe                                                                                                                                                                                                                                 | be            | pe | fe                | data |   |   |   |   |   |   |   |  |
| Reset   | 0        | 0              | 0  | 0  | 0                                                                                                                                                                                                                                  | 0             | 0  | 0                 | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Bits    | Access   | Name           |    |    | Description                                                                                                                                                                                                                        |               |    |                   |      |   |   |   |   |   |   |   |  |
| [15:12] | -        | reserved       |    |    | Reserved                                                                                                                                                                                                                           |               |    |                   |      |   |   |   |   |   |   |   |  |
| [11]    | RO       | oe             |    |    | Overflow error<br>0: No overflow error occurs.<br>1: An overflow error occurs. That is, a data segment is received when the RX FIFO is full.                                                                                       |               |    |                   |      |   |   |   |   |   |   |   |  |
| [10]    | RO       | be             |    |    | Break error<br>0: No break error occurs.<br>1: A break error occurs. That is, the RX data input signal retains low longer than a full word transfer. A full word consists of a start bit, data bits, a parity bit, and a stop bit. |               |    |                   |      |   |   |   |   |   |   |   |  |
| [9]     | RO       | pe             |    |    | Parity error<br>0: No parity error occurs.<br>1: A parity error occurs.                                                                                                                                                            |               |    |                   |      |   |   |   |   |   |   |   |  |
| [8]     | RO       | fe             |    |    | Frame error<br>0: No frame error occurs.<br>1: A frame error (namely, stop bit error) occurs.                                                                                                                                      |               |    |                   |      |   |   |   |   |   |   |   |  |
| [7:0]   | RW       | data           |    |    | Data to be transmitted or received                                                                                                                                                                                                 |               |    |                   |      |   |   |   |   |   |   |   |  |

### UART\_RSR

UART\_RSR is an RX status register or error clear register.

- It acts as the RX status register when being read.
- It acts as the error clear register when being written.

You can obtain the RX status by reading [UART\\_DR](#). The break, frame, and parity status information read from [UART\\_DR](#) takes priority over that read from [UART\\_RSR](#). That is, the status information in [UART\\_DR](#) updates faster than that in [UART\\_RSR](#).



## CAUTION

Writing any value to UART\_RSR resets it.

| Offset Address |          |          | Register Name                                                                                                                                                                                                                                                                                          |    |    |    |    | Total Reset Value |  |
|----------------|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|-------------------|--|
|                | 0x004    |          | UART_RSR                                                                                                                                                                                                                                                                                               |    |    |    |    | 0x00              |  |
| Bit            | 7        | 6        | 5                                                                                                                                                                                                                                                                                                      | 4  | 3  | 2  | 1  | 0                 |  |
| Name           | reserved |          |                                                                                                                                                                                                                                                                                                        | oe | be | pe | fe |                   |  |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                                      | 0  | 0  | 0  | 0  | 0                 |  |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                            |    |    |    |    |                   |  |
| [7:4]          | -        | reserved | Reserved                                                                                                                                                                                                                                                                                               |    |    |    |    |                   |  |
| [3]            | RW       | oe       | Overflow error<br>0: No overflow error occurs.<br>1: An overflow error occurs.<br>When the FIFO is full, the contents in the FIFO remain valid. No data will be written to the FIFO and overflow occurs in the shift register. In this case, the CPU must read the data immediately to spare the FIFO. |    |    |    |    |                   |  |
| [2]            | RW       | be       | Break error<br>0: No break error occurs.<br>1: A break error occurs.<br>If the RX data input signal retains low longer than a full word transfer, a break error is considered. A full word consists of a start bit, data bits, a parity bit, and a stop bit.                                           |    |    |    |    |                   |  |
| [1]            | RW       | pe       | Parity error<br>0: No parity error occurs.<br>1: A parity error of the received data occurs.<br>In FIFO mode, the error is associated with the data at the top of the FIFO.                                                                                                                            |    |    |    |    |                   |  |
| [0]            | RW       | fe       | Frame error<br>0: No frame error occurs.<br>1: An error occurs at the stop bit of the received data. The valid stop bit is 1.                                                                                                                                                                          |    |    |    |    |                   |  |

## UART\_FR

UART\_FR is a UART flag register.



| Offset Address |          |          |                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |   |   |   | Register Name |         |      |      |      | Total Reset Value |          |  |  |  |  |  |
|----------------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---|---|---|---------------|---------|------|------|------|-------------------|----------|--|--|--|--|--|
| Bit            | 0x018    |          |                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |   |   |   |               | UART_FR |      |      |      |                   | 0x0197   |  |  |  |  |  |
| Name           | 15       | 14       | 13                                                                                                                                                                                                                                                                                                                                                                        | 12 | 11 | 10 | 9 | 8 | 7 | 6             | 5       | 4    | 3    | 2    | 1                 | 0        |  |  |  |  |  |
|                | reserved |          |                                                                                                                                                                                                                                                                                                                                                                           |    |    |    |   |   |   |               | txfe    | txff | txff | rxfe | busy              | reserved |  |  |  |  |  |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                                                                                                         | 0  | 0  | 0  | 0 | 1 | 1 | 0             | 0       | 1    | 0    | 1    | 1                 | 1        |  |  |  |  |  |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                                                                                               |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [15:8]         | -        | reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [7]            | RO       | txfe     | This bit is defined by the status of <a href="#">UART_LCR_H[fen]</a> .<br>If <a href="#">UART_LCR_H[fen]</a> is 0, this bit is set to 1 when the TX holding register is empty.<br>If <a href="#">UART_LCR_H[fen]</a> is 1, this bit is set to 1 when the TX FIFO is empty.                                                                                                |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [6]            | RO       | txff     | This bit is defined by the status of <a href="#">UART_LCR_H[fen]</a> .<br>If <a href="#">UART_LCR_H[fen]</a> is 0, this bit is set to 1 when the RX holding register is full.<br>If <a href="#">UART_LCR_H[fen]</a> is 1, this bit is set to 1 when the RX FIFO is full.                                                                                                  |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [5]            | RO       | txff     | This bit is defined by the status of <a href="#">UART_LCR_H[fen]</a> .<br>If <a href="#">UART_LCR_H[fen]</a> is 0, this bit is set to 1 when the TX holding register is full.<br>If <a href="#">UART_LCR_H[fen]</a> is 1, this bit is set to 1 when the TX FIFO is full.                                                                                                  |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [4]            | RO       | rxfe     | This bit is defined by the status of <a href="#">UART_LCR_H[fen]</a> .<br>If <a href="#">UART_LCR_H[fen]</a> is 0, this bit is set to 1 when the RX holding register is empty.<br>If <a href="#">UART_LCR_H[fen]</a> is 1, this bit is set to 1 when the RX FIFO is empty.                                                                                                |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [3]            | RO       | busy     | UART busy/idle status<br>0: The UART is idle or data transmission is complete.<br>1: The UART is busy transmitting data.<br><br>If this bit is set to 1, the status is retained until the entire byte (including all stop bits) is transmitted from the shift register.<br>Regardless of whether the UART is enabled, this bit is set to 1 when the TX FIFO is not empty. |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |
| [2:0]          | -        | reserved | Reserved                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |   |   |   |               |         |      |      |      |                   |          |  |  |  |  |  |



## UART\_IBRD

UART\_IBRD is an integer baud rate register.

| Offset Address |            |            |    |    |                                                                                                        |    |   |   |   | Register Name |   |   |   |   |   |   |   |
|----------------|------------|------------|----|----|--------------------------------------------------------------------------------------------------------|----|---|---|---|---------------|---|---|---|---|---|---|---|
| 0x024          |            |            |    |    |                                                                                                        |    |   |   |   | UART_IBRD     |   |   |   |   |   |   |   |
| Bit            | 15         | 14         | 13 | 12 | 11                                                                                                     | 10 | 9 | 8 | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |   |
| Name           | bauddivint |            |    |    |                                                                                                        |    |   |   |   |               |   |   |   |   |   |   |   |
| Reset          | 0          | 0          | 0  | 0  | 0                                                                                                      | 0  | 0 | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bits           | Access     | Name       |    |    | Description                                                                                            |    |   |   |   |               |   |   |   |   |   |   |   |
| [15:0]         | RW         | bauddivint |    |    | Clock divider corresponding to the integral part of the baud rate<br>All bits are cleared after reset. |    |   |   |   |               |   |   |   |   |   |   |   |

## UART\_FBRD

UART\_FBRD is a decimal baud rate register.



### CAUTION

- The values of UART\_IBRD and UART\_FBRD are updated only after the current data transmission or reception is complete.
- The minimum clock divider is 1, and the maximum clock divider is 65,535. That is, UART\_IBRD cannot be 0, and UART\_FBRD is ignored if UART\_IBRD is 0. If UART\_FBRD is set to 0x1E and UART\_IBRD is set to 0x01, the integral part of the clock divider is 30 and the decimal part of the clock divider is 0.015625. Therefore, the clock divider is 30.015625.
- UART baud rate = Internal bus frequency/(16 x Clock divider) = Internal bus frequency/(16 x 30.015625)

| Offset Address |          |             |   |             |                                                                                                       |   |   |   |  | Register Name |  |  |  |  |  |  |  |
|----------------|----------|-------------|---|-------------|-------------------------------------------------------------------------------------------------------|---|---|---|--|---------------|--|--|--|--|--|--|--|
| 0x028          |          |             |   |             |                                                                                                       |   |   |   |  | UART_FBRD     |  |  |  |  |  |  |  |
| Bit            | 7        | 6           | 5 | 4           | 3                                                                                                     | 2 | 1 | 0 |  |               |  |  |  |  |  |  |  |
| Name           | reserved |             |   | banddivfrac |                                                                                                       |   |   |   |  |               |  |  |  |  |  |  |  |
| Reset          | 0        | 0           | 0 | 0           | 0                                                                                                     | 0 | 0 | 0 |  |               |  |  |  |  |  |  |  |
| Bits           | Access   | Name        |   |             | Description                                                                                           |   |   |   |  |               |  |  |  |  |  |  |  |
| [7:6]          | -        | reserved    |   |             | Reserved                                                                                              |   |   |   |  |               |  |  |  |  |  |  |  |
| [5:0]          | RW       | banddivfrac |   |             | Clock divider corresponding to the decimal part of the baud rate<br>All bits are cleared after reset. |   |   |   |  |               |  |  |  |  |  |  |  |



## UART\_LCR\_H

UART\_LCR\_H is a transfer mode control register. The registers UART\_LCR\_H, [UART\\_IBRD](#), and [UART\\_FBRD](#) constitute a 30-bit register. If [UART\\_IBRD](#) and [UART\\_FBRD](#) are updated, UART\_LCR\_H must also be updated.

|        | Offset Address |          | Register Name |                                                                                                                                                                                                                                                                                                                                       |    |    |   |   |   |   |     |      | Total Reset Value |      |     |     |     |
|--------|----------------|----------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|-----|------|-------------------|------|-----|-----|-----|
|        | 0x02C          |          | UART_LCR_H    |                                                                                                                                                                                                                                                                                                                                       |    |    |   |   |   |   |     |      | 0x0000            |      |     |     |     |
| Bit    | 15             | 14       | 13            | 12                                                                                                                                                                                                                                                                                                                                    | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4    | 3                 | 2    | 1   | 0   |     |
| Name   | reserved       |          |               |                                                                                                                                                                                                                                                                                                                                       |    |    |   |   |   |   | sps | wlen | fen               | stp2 | eps | pen | brk |
| Reset  | 0              | 0        | 0             | 0                                                                                                                                                                                                                                                                                                                                     | 0  | 0  | 0 | 0 | 0 | 0 | 0   | 0    | 0                 | 0    | 0   | 0   |     |
| Bits   | Access         | Name     |               | Description                                                                                                                                                                                                                                                                                                                           |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [15:8] | -              | reserved |               | Reserved                                                                                                                                                                                                                                                                                                                              |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [7]    | RW             | sps      |               | Parity select<br>When bit 1, bit 2, and bit 7 of this register are set to 1, the parity bit is 0 during transmission and detection.<br>When bit 1 and bit 7 are set to 1 and bit 2 is set to 0, the parity bit is 1 during transmission and detection.<br>When bit 1, bit 2, and bit 7 are cleared, the stick parity bit is disabled. |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [6:5]  | RW             | wlen     |               | Count of bits in a transmitted or received frame<br>00: 5 bits<br>01: 6 bits<br>10: 7 bits<br>11: 8 bits                                                                                                                                                                                                                              |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [4]    | RW             | fen      |               | TX/RX FIFO enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                                        |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [3]    | RW             | stp2     |               | Whether a 2-bit stop bit exists at the end of a transmitted frame<br>0: There is no 2-bit stop bit at the end of the transmitted frame.<br>1: There is a 2-bit stop bit at the end of the transmitted frame.<br>The RX logic does not check for the 2-bit stop bit during data reception.                                             |    |    |   |   |   |   |     |      |                   |      |     |     |     |
| [2]    | RW             | eps      |               | Parity bit select during data transmission and reception<br>0: The odd parity bit is generated or checked during data transmission and reception.<br>1: The even parity bit is generated or checked during data transmission and reception.<br>This bit is invalid when UART_LCR_H[fen] is 0.                                         |    |    |   |   |   |   |     |      |                   |      |     |     |     |



|     |    |     |                                                                                                                                                                                                                                                                                        |
|-----|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | RW | pen | Parity check enable<br>0: The parity check is disabled.<br>1: The parity bit is generated at the TX end and checked at the RX end.                                                                                                                                                     |
| [0] | RW | brk | Break TX<br>0: invalid<br>1: After the current data transmission is complete, the UTXD outputs low level continuously.<br>Note: This bit must retain 1 for at least two full frames to ensure that the break command is executed properly. In normal cases, this bit must be set to 0. |

## UART\_CR

UART\_CR is a UART control register.

To configure UART\_CR, perform the following steps:

- Step 1** Write 0 to UART\_CR[uarten] to disable the UART.
- Step 2** Wait until the current data transmission or reception is complete.
- Step 3** Set [UART\\_LCR\\_H\[fen\]](#) to 0.
- Step 4** Configure UART\_CR.
- Step 5** Write 1 to UART\_CR[uarten] to enable the UART.

----End

|       |        | Offset Address |          |    |                                                                                                                                      | Register Name |     |     |     | Total Reset Value |   |   |   |        |   |   |   |
|-------|--------|----------------|----------|----|--------------------------------------------------------------------------------------------------------------------------------------|---------------|-----|-----|-----|-------------------|---|---|---|--------|---|---|---|
|       |        | 0x030          |          |    |                                                                                                                                      | UART_CR       |     |     |     | 0x0300            |   |   |   |        |   |   |   |
| Bit   | 15     | 14             | 13       | 12 | 11                                                                                                                                   | 10            | 9   | 8   | 7   | 6                 | 5 | 4 | 3 | 2      | 1 | 0 |   |
| Name  | ctsen  | rtsen          | reserved |    | rts                                                                                                                                  | dtr           | rxe | txe | lbe | reserved          |   |   |   | uarten |   |   |   |
| Reset | 0      | 0              | 0        | 0  | 0                                                                                                                                    | 0             | 1   | 1   | 0   | 0                 | 0 | 0 | 0 | 0      | 0 | 0 | 0 |
| Bits  | Access | Name           |          |    | Description                                                                                                                          |               |     |     |     |                   |   |   |   |        |   |   |   |
| [15]  | RW     | ctsen          |          |    | CTS hardware flow control enable<br>0: disabled<br>1: enabled. Data can be transmitted only when the nUARTCTS signal is valid.       |               |     |     |     |                   |   |   |   |        |   |   |   |
| [14]  | RW     | rtsen          |          |    | RTS hardware flow control enable<br>0: disabled<br>1: enabled. The data RX request can be sent only when the RX FIFO has free space. |               |     |     |     |                   |   |   |   |        |   |   |   |



|         |    |          |                                                                                                                                                                                                  |
|---------|----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:12] | -  | reserved | Reserved                                                                                                                                                                                         |
| [11]    | RW | rts      | Request TX<br>This bit is the inversion of the status output signal nUARTRTS of the UART modem.<br>0: The output signal is retained.<br>1: When this bit is set to 1, the output signal is 0.    |
| [10]    | RW | dtr      | Data TX ready<br>This bit is the inversion of the status output signal nUARTDTR of the UART modem.<br>0: The output signal is retained.<br>1: When this bit is set to 1, the output signal is 0. |
| [9]     | RW | rxen     | UART RX enable<br>0: disabled<br>1: enabled<br>If the UART is disabled during data reception, the current data reception is stopped abnormally.                                                  |
| [8]     | RW | txen     | UART TX enable<br>0: disabled<br>1: enabled<br>If the UART is disabled during data transmission, the current data transmission is stopped abnormally.                                            |
| [7]     | RW | lbe      | Loopback enable<br>0: disabled<br>1: UARTRXD output is looped back to UARTTXD.                                                                                                                   |
| [6:1]   | -  | reserved | Reserved                                                                                                                                                                                         |
| [0]     | RW | uarten   | UART enable<br>0: disabled<br>1: enabled<br>If the UART is disabled during data reception and transmission, the data transfer is stopped abnormally.                                             |

## UART\_IFLS

UART\_IFLS is an interrupt FIFO threshold register. It is used to set the trigger threshold for the FIFO interrupt (UART\_TXINTR or UART\_RXINTR).



| Offset Address |          |          |    |    |                                                                                                                                                                                                                                                                                                 |    |   |   |   | Register Name |          |   |   |          | Total Reset Value |   |   |  |  |
|----------------|----------|----------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|---|---|---------------|----------|---|---|----------|-------------------|---|---|--|--|
|                | 0x034    |          |    |    |                                                                                                                                                                                                                                                                                                 |    |   |   |   | UART_IFLS     |          |   |   |          | 0x0012            |   |   |  |  |
| Bit            | 15       | 14       | 13 | 12 | 11                                                                                                                                                                                                                                                                                              | 10 | 9 | 8 | 7 | 6             | 5        | 4 | 3 | 2        | 1                 | 0 |   |  |  |
| Name           | reserved |          |    |    |                                                                                                                                                                                                                                                                                                 |    |   |   |   |               | rxiflsel |   |   | txiflsel |                   |   |   |  |  |
| Reset          | 0        | 0        | 0  | 0  | 0                                                                                                                                                                                                                                                                                               | 0  | 0 | 0 | 0 | 0             | 0        | 1 | 0 | 0        | 0                 | 1 | 0 |  |  |
| Bits           | Access   | Name     |    |    | Description                                                                                                                                                                                                                                                                                     |    |   |   |   |               |          |   |   |          |                   |   |   |  |  |
| [15:6]         | -        | reserved |    |    | Reserved                                                                                                                                                                                                                                                                                        |    |   |   |   |               |          |   |   |          |                   |   |   |  |  |
| [5:3]          | RW       | rxiflsel |    |    | RX interrupt FIFO threshold. An RX interrupt is triggered when any of the following conditions is met:<br><br>000: RX FIFO $\geq$ 1/8 full<br>001: RX FIFO $\geq$ 1/4 full<br>010: RX FIFO $\geq$ 1/2 full<br>011: RX FIFO $\geq$ 3/4 full<br>100: RX FIFO $\geq$ 7/8 full<br>101–111: reserved |    |   |   |   |               |          |   |   |          |                   |   |   |  |  |
| [2:0]          | RW       | txiflsel |    |    | TX interrupt FIFO threshold. A TX interrupt is triggered when any of the following conditions is met:<br><br>000: TX FIFO $\leq$ 1/8 full<br>001: TX FIFO $\leq$ 1/4 full<br>011: TX FIFO $\leq$ 3/4 full<br>010: TX FIFO $\leq$ 1/2 full<br>100: TX FIFO $\leq$ 7/8 full<br>101–111: reserved  |    |   |   |   |               |          |   |   |          |                   |   |   |  |  |

## UART\_IMSC

UART\_IMSC is an interrupt mask register.

| Offset Address |          |          |    |    |             |    |   |   |   | Register Name |      |      |      |      | Total Reset Value |          |   |   |   |
|----------------|----------|----------|----|----|-------------|----|---|---|---|---------------|------|------|------|------|-------------------|----------|---|---|---|
|                | 0x038    |          |    |    |             |    |   |   |   | UART_IMSC     |      |      |      |      | 0x0000            |          |   |   |   |
| Bit            | 15       | 14       | 13 | 12 | 11          | 10 | 9 | 8 | 7 | 6             | 5    | 4    | 3    | 2    | 1                 | 0        |   |   |   |
| Name           | reserved |          |    |    |             |    |   |   |   |               | beim | peim | feim | rtim | txim              | reserved |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0           | 0  | 0 | 0 | 0 | 0             | 0    | 0    | 0    | 0    | 0                 | 0        | 0 | 0 | 0 |
| Bits           | Access   | Name     |    |    | Description |    |   |   |   |               |      |      |      |      |                   |          |   |   |   |
| [15:11]        | -        | reserved |    |    | Reserved    |    |   |   |   |               |      |      |      |      |                   |          |   |   |   |



|       |    |          |                                                             |
|-------|----|----------|-------------------------------------------------------------|
| [10]  | RW | oeim     | Overflow error interrupt mask<br>0: masked<br>1: not masked |
| [9]   | RW | beim     | Break error interrupt mask<br>0: masked<br>1: not masked    |
| [8]   | RW | peim     | Parity check interrupt mask<br>0: masked<br>1: not masked   |
| [7]   | RW | feim     | Frame error interrupt mask<br>0: masked<br>1: not masked    |
| [6]   | RW | rtim     | RX timeout interrupt mask<br>0: masked<br>1: not masked     |
| [5]   | RW | txim     | TX interrupt mask<br>0: masked<br>1: not masked             |
| [4]   | RW | rxim     | RX interrupt mask<br>0: masked<br>1: not masked             |
| [3:0] | -  | reserved | Reserved                                                    |

## UART\_RIS

UART\_RIS is a raw interrupt status register. The contents of this register are not affected by the UART\_IMSC register.

|         | Offset Address |          | Register Name |    |             |       |       |       |       |        |       |       | Total Reset Value |   |   |   |
|---------|----------------|----------|---------------|----|-------------|-------|-------|-------|-------|--------|-------|-------|-------------------|---|---|---|
|         | 0x03C          |          | UART_RIS      |    |             |       |       |       |       |        |       |       | 0x0000            |   |   |   |
| Bit     | 15             | 14       | 13            | 12 | 11          | 10    | 9     | 8     | 7     | 6      | 5     | 4     | 3                 | 2 | 1 | 0 |
| Name    | reserved       |          |               |    |             | oeris | beris | peris | feris | rtiris | ttris | rxris | reserved          |   |   |   |
| Reset   | 0              | 0        | 0             | 0  | 0           | 0     | 0     | 0     | 0     | 0      | 0     | 0     | 0                 | 0 | 0 | 0 |
| Bits    | Access         | Name     |               |    | Description |       |       |       |       |        |       |       |                   |   |   |   |
| [15:11] | -              | reserved |               |    | Reserved    |       |       |       |       |        |       |       |                   |   |   |   |



|       |    |          |                                                                                                       |
|-------|----|----------|-------------------------------------------------------------------------------------------------------|
| [10]  | RO | oeris    | Raw overflow error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [9]   | RO | beris    | Raw break error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.    |
| [8]   | RO | peris    | Raw parity check interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.   |
| [7]   | RO | feris    | Raw error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |
| [6]   | RO | rtris    | Raw RX timeout interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.     |
| [5]   | RO | txris    | Raw TX interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |
| [4]   | RO | rxris    | Raw RX interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |
| [3:0] | -  | reserved | Reserved                                                                                              |

## UART\_MIS

UART\_MIS is a masked interrupt status register. The values of this register are the results obtained after UART\_RIS is ANDed with UART\_IMSC.

|         | Offset Address<br>0x040 |          |    |    |             |    |       |        |       |        | Register Name<br>UART_MIS |       |          |   |   |   |  |  | Total Reset Value<br>0x0000 |
|---------|-------------------------|----------|----|----|-------------|----|-------|--------|-------|--------|---------------------------|-------|----------|---|---|---|--|--|-----------------------------|
| Bit     | 15                      | 14       | 13 | 12 | 11          | 10 | 9     | 8      | 7     | 6      | 5                         | 4     | 3        | 2 | 1 | 0 |  |  |                             |
| Name    | reserved                |          |    |    |             |    | bemis | permis | femis | rtrmis | txmis                     | rxmis | reserved |   |   |   |  |  |                             |
| Reset   | 0                       | 0        | 0  | 0  | 0           | 0  | 0     | 0      | 0     | 0      | 0                         | 0     | 0        | 0 | 0 | 0 |  |  |                             |
| Bits    | Access                  | Name     |    |    | Description |    |       |        |       |        |                           |       |          |   |   |   |  |  |                             |
| [15:11] | -                       | reserved |    |    | Reserved    |    |       |        |       |        |                           |       |          |   |   |   |  |  |                             |



|       |    |          |                                                                                                          |
|-------|----|----------|----------------------------------------------------------------------------------------------------------|
| [10]  | RO | oemis    | Masked overflow error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [9]   | RO | bemis    | Masked break error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.    |
| [8]   | RO | pemis    | Masked parity check interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.   |
| [7]   | RO | femis    | Masked error interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |
| [6]   | RO | rtmis    | Masked RX timeout interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.     |
| [5]   | RO | txmis    | Masked TX interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |
| [4]   | RO | rxmis    | Masked RX interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |
| [3:0] | -  | reserved | Reserved                                                                                                 |

## UART\_ICR

UART\_ICR is an interrupt clear register. Writing 1 clears the corresponding interrupt, and writing 0 has no effect.

| Offset Address |          | Register Name |       |     |             |      |      |      |      |      |      | Total Reset Value |     |
|----------------|----------|---------------|-------|-----|-------------|------|------|------|------|------|------|-------------------|-----|
| 0x044          |          | UART_ICR      |       |     |             |      |      |      |      |      |      | 0x0000            |     |
| Bit            | 15 14    | 13 12         | 11 10 | 9   | 8           | 7    | 6    | 5    | 4    | 3    | 2    | 1                 | 0   |
| Name           | reserved |               |       |     | oeic        | beic | peic | feic | rtic | txic | rxic | reserved          |     |
| Reset          | 0 0      | 0 0           | 0 0   | 0 0 | 0 0         | 0 0  | 0 0  | 0 0  | 0 0  | 0 0  | 0 0  | 0 0               | 0 0 |
| Bits           | Access   | Name          |       |     | Description |      |      |      |      |      |      |                   |     |
| [15:11]        | -        | reserved      |       |     | Reserved    |      |      |      |      |      |      |                   |     |



|       |    |          |                                                            |
|-------|----|----------|------------------------------------------------------------|
| [10]  | WO | oeic     | Overflow error interrupt clear<br>0: invalid<br>1: cleared |
| [9]   | WO | beic     | Break error interrupt clear<br>0: invalid<br>1: cleared    |
| [8]   | WO | peic     | Parity check interrupt clear<br>0: invalid<br>1: cleared   |
| [7]   | WO | feic     | Error interrupt clear<br>0: invalid<br>1: cleared          |
| [6]   | WO | rtic     | RX timeout interrupt clear<br>0: invalid<br>1: cleared     |
| [5]   | WO | txic     | TX interrupt clear<br>0: invalid<br>1: cleared             |
| [4]   | WO | rxic     | RX interrupt clear<br>0: invalid<br>1: cleared             |
| [3:0] | -  | reserved | Reserved                                                   |

## UART\_DMCR

UART\_DMCR is a DMA control register. It is used to enable or disable the DMAs of the TX and RX FIFOs.

|        | Offset Address 0x048 |          |    |             |    |    |   |   |   |   |   |   |   |   |   | Register Name UART_DMCR |        |        |  |
|--------|----------------------|----------|----|-------------|----|----|---|---|---|---|---|---|---|---|---|-------------------------|--------|--------|--|
| Bit    | 15                   | 14       | 13 | 12          | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                       |        |        |  |
| Name   | reserved             |          |    |             |    |    |   |   |   |   |   |   |   |   |   | dmaonerr                | txdmae | rxdmae |  |
| Reset  | 0                    | 0        | 0  | 0           | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                       | 0      |        |  |
| Bits   | Access               | Name     |    | Description |    |    |   |   |   |   |   |   |   |   |   |                         |        |        |  |
| [15:3] | -                    | reserved |    | Reserved    |    |    |   |   |   |   |   |   |   |   |   |                         |        |        |  |



|     |    |          |                                                                                                                                                                                                                                                                                                                              |
|-----|----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | RW | dmaonerr | DMA enable for the RX channel when the UART error interrupt (UARTEINTR) is generated<br>0: When UARTEINTR is valid, the DMA output request (UARTRXDMASREQ or UARRTXDMABREQ) of the RX channel is valid.<br>1: When UARTEINTR is valid, the DMA output request (UARTRXDMASREQ or UARRTXDMABREQ) of the RX channel is invalid. |
| [1] | RW | txdmae   | TX FIFO DMA enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                              |
| [0] | RW | rxdmae   | RX FIFO DMA enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                              |

## 11.3 I<sup>2</sup>C

### 11.3.1 Overview

The I<sup>2</sup>C module serves as a slave on the advanced peripheral bus (APB) and a master on the I<sup>2</sup>C bus. It allows the CPU to read/write data from/to slave devices on the I<sup>2</sup>C bus.

### 11.3.2 Function Description

The I<sup>2</sup>C module has the following features:

- Supports the I<sup>2</sup>C bus protocol V2.0 and only the master mode.
- Acts as a slave on the APB bus and a master on the I<sup>2</sup>C bus and supports bus arbitration when there are multiple masters.
- Supports clock synchronization as well as bit and byte waiting.
- Supports the interrupt or polling operation.
- Supports the standard address (7 bits) and extended address (10 bits).
- Works at the standard mode (100 kbit/s) and fast mode (400 kbit/s).
- Supports general call and start byte.
- Does not support the C-Bus device on the I<sup>2</sup>C bus.
- Filters the received SDA and SCL signals.

### 11.3.3 Operating Mode

#### 11.3.3.1 Initializing the I<sup>2</sup>C

The I<sup>2</sup>C master can write data to the slave or receive data from the slave. [Figure 11-3](#) shows the process for transmitting data by using the I<sup>2</sup>C master.

**Figure 11-3** Process for transmitting data by using the I<sup>2</sup>C master

### 11.3.3.2 Receiving Data by Using the I<sup>2</sup>C Master

Figure 11-4 shows the process for receiving data by using the I<sup>2</sup>C master.

**Figure 11-4** Process for receiving data by using the I<sup>2</sup>C master





## 11.3.4 Register Summary

Hi3796M V100 has three I<sup>2</sup>C modules. The following are the base addresses for the I<sup>2</sup>C registers:

- The base address for I<sup>2</sup>C0 registers is 0xF8B1\_0000.
- The base address for I<sup>2</sup>C1 registers is 0xF8B1\_1000.
- The base address for I<sup>2</sup>C2 registers is 0xF8B1\_2000.

Table 11-4 describes I<sup>2</sup>C registers.

**Table 11-4** Summary of I<sup>2</sup>C registers

| Offset Address | Register  | Description                                           | Page                  |
|----------------|-----------|-------------------------------------------------------|-----------------------|
| 0x00           | I2C_CTRL  | I <sup>2</sup> C control register                     | <a href="#">11-29</a> |
| 0x04           | I2C_COM   | I <sup>2</sup> C command register                     | <a href="#">11-31</a> |
| 0x08           | I2C_ICR   | I <sup>2</sup> C interrupt clear register             | <a href="#">11-32</a> |
| 0x0C           | I2C_SR    | I <sup>2</sup> C module status register               | <a href="#">11-33</a> |
| 0x10           | I2C_SCL_H | I <sup>2</sup> C SCL high-level cycle number register | <a href="#">11-34</a> |
| 0x14           | I2C_SCL_L | I <sup>2</sup> C SCL low-level cycle number register  | <a href="#">11-35</a> |
| 0x18           | I2C_TXR   | I <sup>2</sup> C TX data register                     | <a href="#">11-35</a> |
| 0x1C           | I2C_RXR   | I <sup>2</sup> C RX data register                     | <a href="#">11-36</a> |

## 11.3.5 Register Description

### I2C\_CTRL

I2C\_CTRL is an I<sup>2</sup>C control register. It is used to enable I<sup>2</sup>C modules and mask interrupts.





|     |    |               |                                                                      |
|-----|----|---------------|----------------------------------------------------------------------|
| [0] | RW | int_done_mask | Bus transfer completion interrupt mask<br>0: masked<br>1: not masked |
|-----|----|---------------|----------------------------------------------------------------------|

## I2C\_COM

I2C\_COM is an I<sup>2</sup>C command register. It is used to configure the commands for the I<sup>2</sup>C module.



### CAUTION

During or before system initialization, the corresponding interrupts must be cleared.  
I2C\_COM bit[3:0] are automatically cleared after operations are complete.

|        | Offset Address<br>0x04 |          |    |                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>I2C_COM |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |        |          |       |       |         |   |   |
|--------|------------------------|----------|----|------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|---|---|----------------------------------|--------|----------|-------|-------|---------|---|---|
| Bit    | 31                     | 30       | 29 | 28                                                                                       | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6      | 5        | 4     | 3     | 2       | 1 | 0 |
| Name   | reserved               |          |    |                                                                                          |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  | op_ack | op_start | op_rd | op_we | op_stop |   |   |
| Reset  | 0                      | 0        | 0  | 0                                                                                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0      | 0        | 0     | 0     | 0       |   |   |
| Bits   | Access                 | Name     |    | Description                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |
| [31:5] | -                      | reserved |    | Reserved                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |
| [4]    | RW                     | op_ack   |    | Whether the master sends an ACK as a receiver<br>0: yes<br>1: no                         |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |
| [3]    | RW                     | op_start |    | Start condition operation<br>0: The operation is complete.<br>1: The operation is valid. |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |
| [2]    | RW                     | op_rd    |    | Read operation<br>0: The operation is complete.<br>1: The operation is valid.            |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |
| [1]    | RW                     | op_we    |    | Write operation<br>0: The operation is complete.<br>1: The operation is valid.           |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                                  |        |          |       |       |         |   |   |

|     |    |         |                                                                                         |
|-----|----|---------|-----------------------------------------------------------------------------------------|
| [0] | RW | op_stop | Stop condition operation<br>0: The operation is complete.<br>1: The operation is valid. |
|-----|----|---------|-----------------------------------------------------------------------------------------|

## I2C\_ICR

I2C\_ICR is an I<sup>2</sup>C interrupt clear register.



## **CAUTION**

When a new interrupt is generated, the I<sup>2</sup>C module automatically clears the corresponding bit of I2C\_ICR.



|     |    |                  |                                                                         |
|-----|----|------------------|-------------------------------------------------------------------------|
| [2] | WC | clr_int_ack_err  | Slave ACK error interrupt clear<br>0: not cleared<br>1: cleared         |
| [1] | WC | clr_int_arb_loss | Bus arbitration failure interrupt clear<br>0: not cleared<br>1: cleared |
| [0] | WC | clr_int_done     | Bus transfer completion interrupt clear<br>0: not cleared<br>1: cleared |

## I2C\_SR

I2C\_SR is an I<sup>2</sup>C module status register. It is used to read the operating status of the I<sup>2</sup>C module.



### CAUTION

I2C\_SR bit[1] indicates the I<sup>2</sup>C bus arbitration failure. When I2C\_SR bit[1] is valid, the current operation fails. Before clearing I2C\_SR bit[1], you must clear other interrupts, clear I2C\_COM or write a new operation command to I2C\_COM and then clear I2C\_SR bit[1].

|        | Offset Address<br>0x0C |          |    |    |                                      |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>I2C_SR |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |          |           |          |        |        |             |              |          |
|--------|------------------------|----------|----|----|--------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|---|---|----------------------------------|----------|-----------|----------|--------|--------|-------------|--------------|----------|
| Bit    | 31                     | 30       | 29 | 28 | 27                                   | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6        | 5         | 4        | 3      | 2      | 1           | 0            |          |
| Name   | reserved               |          |    |    |                                      |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |                                  | bus_busy | int_start | int_stop | int_tx | int_rx | int_ack_err | int_arb_loss | int_done |
| Reset  | 0                      | 0        | 0  | 0  | 0                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0        | 0         | 0        | 0      | 0      | 0           |              |          |
| Bits   | Access                 | Name     |    |    | Description                          |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |                                  |          |           |          |        |        |             |              |          |
| [31:8] | -                      | reserved |    |    | Reserved                             |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |                                  |          |           |          |        |        |             |              |          |
| [7]    | RO                     | bus_busy |    |    | Bus busy flag<br>0: ready<br>1: busy |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |                                  |          |           |          |        |        |             |              |          |



|     |    |              |                                                                                                                       |
|-----|----|--------------|-----------------------------------------------------------------------------------------------------------------------|
| [6] | RO | int_start    | Master start condition TX completion interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [5] | RO | int_stop     | Master stop condition TX completion interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.  |
| [4] | RO | int_tx       | Master TX interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.                            |
| [3] | RO | int_rx       | Master RX interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.                            |
| [2] | RO | int_ack_err  | Slave ACK error interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.                      |
| [1] | RO | int_arb_loss | Bus arbitration failure interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.              |
| [0] | RO | int_done     | Bus transfer completion interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.              |

## I2C\_SCL\_H

I2C\_SCL\_H is an I<sup>2</sup>C SCL high-level cycle number register. It is used to configure the number of SCL high-level cycles when the I<sup>2</sup>C module is working.



### CAUTION

During or before system initialization, set [I2C\\_CTRL](#) bit[7] to 0.



| Offset Address |          |          |    |    |    |                                                                                                                      |    |    |    |    |    |    |    |    |    | Register Name |       |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|----------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|-------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x10           |          |          |    |    |    |                                                                                                                      |    |    |    |    |    |    |    |    |    | I2C_SCL_H     |       |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                                                                                   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |    |                                                                                                                      |    |    |    |    |    |    |    |    |    |               | scl_h |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                                                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    |    | Description                                                                                                          |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved |    |    |    | Reserved                                                                                                             |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | scl_h    |    |    |    | Number of SCL high-level cycles. The actual number of SCL high-level cycles is the configured value multiplied by 2. |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## I2C\_SCL\_L

I2C\_SCL\_L is an I<sup>2</sup>C SCL low-level cycle number register. It is used to configure the number of SCL low-level cycles when the I<sup>2</sup>C module is working.



### CAUTION

During or before system initialization, set [I2C\\_CTRL](#) bit[7] to 0.

| Offset Address |          |          |    |    |    |                                                                                                                    |    |    |    |    |    |    |    |    |    | Register Name |       |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|--------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|-------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x14           |          |          |    |    |    |                                                                                                                    |    |    |    |    |    |    |    |    |    | I2C_SCL_L     |       |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                                                                                 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |    |                                                                                                                    |    |    |    |    |    |    |    |    |    |               | scl_l |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                                                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    |    | Description                                                                                                        |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved |    |    |    | Reserved                                                                                                           |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | scl_l    |    |    |    | Number of SCL low-level cycles. The actual number of SCL low-level cycles is the configured value multiplied by 2. |    |    |    |    |    |    |    |    |    |               |       |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## I2C\_TXR

I2C\_TXR is an I<sup>2</sup>C TX data register. It is used to configure the data to be transmitted.



## CAUTION

After data transmission is complete, the I<sup>2</sup>C module does not modify I2C\_TXR.

|        | Offset Address |          |    |    |                                        |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |   |   |   |   |   |
|--------|----------------|----------|----|----|----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|---|---|---|---|---|
|        | 0x18           |          |    |    |                                        |    |    |    |    |    |    |    |    |    |    |    | I2C_TXR       |    |    |    |    |    |   |   | 0x0000_0000       |   |   |   |   |   |   |   |
| Bit    | 31             | 30       | 29 | 28 | 27                                     | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | reserved       |          |    |    |                                        |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   | i2c_txr           |   |   |   |   |   |   |   |
| Reset  | 0              | 0        | 0  | 0  | 0                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits   | Access         | Name     |    |    | Description                            |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [31:8] | -              | reserved |    |    | Reserved                               |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [7:0]  | RW             | i2c_txr  |    |    | Data to be transmitted from the master |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |

## I2C\_RXR

I2C\_RXR is an I<sup>2</sup>C RX data register. It is used to store data received by the master from the slave.

|        | Offset Address |          |    |    |                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |         |   |   |   |   |   |   |
|--------|----------------|----------|----|----|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---------|---|---|---|---|---|---|
|        | 0x1C           |          |    |    |                             |    |    |    |    |    |    |    |    |    |    |    | I2C_RXR       |    |    |    |    |    |   |   | 0x0000_0000       |         |   |   |   |   |   |   |
| Bit    | 31             | 30       | 29 | 28 | 27                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6       | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | reserved       |          |    |    |                             |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   | i2c_rxr |   |   |   |   |   |   |
| Reset  | 0              | 0        | 0  | 0  | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0       | 0 | 0 | 0 | 0 |   |   |
| Bits   | Access         | Name     |    |    | Description                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |         |   |   |   |   |   |   |
| [31:8] | -              | reserved |    |    | Reserved                    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |         |   |   |   |   |   |   |
| [7:0]  | RO             | i2c_rxr  |    |    | Data received by the master |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |         |   |   |   |   |   |   |

## 11.4 IR

### 11.4.1 Overview

The IR module receives data over an infrared interface.

### 11.4.2 Features

The IR module has the following features:

- Allows software to disable the IR module.
- Supports two operating modes:
  - Mode 0 supports RX data error detection, IR wakeup, and decoding in the formats of NEC with simple repeat code, NEC with full repeat code, SONY, and TC9012.
  - Mode 1 supports symbol level width detection in any data format.
- Supports the RX data frame overflow interrupt, RX data frame format error interrupt, RX data frame interrupt, key release interrupt, and combined interrupt in mode 0.
- Supports the RX symbol overflow interrupt, symbol RX interrupt, symbol timeout interrupt, and combined interrupt in mode 1.
- Supports querying of the status of raw and masked interrupts.
- Supports interrupt clear and mask (write to clear).
- Supports IR wakeup.
- Supports the reference clock frequency ranging from 1 MHz to 128 MHz and controls the clock divider by means of software programming, enabling the working clock frequency to be prescaled to 1 MHz.

### 11.4.3 Function Description

When the IR module receives infrared signals transmitted by an infrared remote control, it decodes the signals and transmits the decoded signals to the ARM subsystem. The ARM subsystem performs corresponding operations based on the received codes to implement the expected function. The IR module connects to the APB in the ARM subsystem.

[Figure 11-5](#) shows the functional block diagram of the IR module.

**Figure 11-5** Functional block diagram of the IR module





The analysis on the signals transmitted by various infrared remote controls shows that the lead codes in the infrared commands vary according to remote controls. The subsequent control commands and the number of command code bits are also different. This is because infrared remote controls are not designed based on a unified standard. The basic encoding principles, however, are the same. The pulses with different cycles and duty ratios are used to represent 0 and 1. The duty ratios and pulse cycles may vary according to remote controls. Based on these differences, the code formats of infrared data are classified into the following: NEC with simple repeat code, NEC with full repeat code, TC9012 code, and SONY code.

Table 11-5 to Table 11-7 describe the code formats of the received infrared data.

**Table 11-5** Code formats of the received infrared data (NEC with simple repeat code)

| Data Format                |         | NEC with Simple Repeat Code |                    |             |                |
|----------------------------|---------|-----------------------------|--------------------|-------------|----------------|
|                            |         | uPD6121G                    | D6121/BU5777/D1913 | LC7461M-C13 | AEHA           |
| Lead code (10 μs)          | LEAD_S  | 900                         | 900                | 900         | 337.6          |
|                            | LEAD_E  | 450                         | 450                | 450         | 168.8          |
| Bit 0 (10 μs)              | B0_L    | 56                          | 56                 | 56          | 42.2           |
|                            | B0_H    | 56                          | 56                 | 56          | 42.2           |
| Bit 1 (10 μs)              | B1_L    | 56                          | 56                 | 56          | 42.2           |
|                            | B1_H    | 169                         | 169                | 169         | 126.6          |
| Simple repeat code (10 μs) | SLEAD_S | 900                         | 900                | 900         | 337.6          |
|                            | SLEAD_E | 225                         | 225                | 225         | 337.6          |
| Burst (10 μs)              |         | 55                          | 55                 | 55          | 42.2           |
| Frame length (10 μs)       |         | 10800                       | 10800              | 10800       | 8777.6–12828.8 |
| Valid data bit             |         | 32                          | 32                 | 42          | 48             |

**Table 11-6** Code formats of the received infrared data (NEC with full repeat code)

| Data Format       |        | NEC with Full Repeat Code |              |              |              |        |        |           |
|-------------------|--------|---------------------------|--------------|--------------|--------------|--------|--------|-----------|
|                   |        | uPD6121G                  | LC7461 M-C13 | MN602 4-C5D6 | MN6014 -C6D6 | MATNEW | MN6030 | PANASONIC |
| Lead code (10 μs) | LEAD_S | 900                       | 900          | 337.6        | 349.2        | 348.8  | 349    | 352       |
|                   | LEAD_E | 450                       | 450          | 337.6        | 349.2        | 374.4  | 349    | 352       |
| Bit 0 (10 μs)     | B0_L   | 56                        | 56           | 84.4         | 87.3         | 43.6   | 87.3   | 88        |
|                   | B0_H   | 56                        | 56           | 84.4         | 87.3         | 43.6   | 87.3   | 88        |
| Bit1 (10)         | B1_L   | 56                        | 56           | 84.4         | 87.3         | 43.6   | 87.3   | 88        |



| Data Format                |         | NEC with Full Repeat Code |                 |                 |                 |                     |        |               |
|----------------------------|---------|---------------------------|-----------------|-----------------|-----------------|---------------------|--------|---------------|
|                            |         | uPD6121G                  | LC7461<br>M-C13 | MN602<br>4-C5D6 | MN6014<br>-C6D6 | MATNEW              | MN6030 | PANA<br>SONIC |
| μs)                        | B1_H    | 169                       | 169             | 253.2           | 174.6           | 130.8               | 261.9  | 264           |
| Simple repeat code (10 μs) | SLEAD_S | None                      | None            | None            | None            | None                | None   | None          |
|                            | SLEAD_E |                           |                 |                 |                 |                     |        |               |
| Burst (10 μs)              |         | 55                        | 55              | 84.4            | 87.3            | 43.6                | 87.3   | 88            |
| Frame length (10 μs)       |         | 10800                     | 10800           | 10130           | 10470           | 12413.6–16<br>594.4 | 10500  | 10400         |
| Valid data bit             |         | 32                        | 42              | 22              | 24              | 48                  | 22     | 22            |

**Table 11-7** Code formats of the received infrared data (TC9012 code and SONY code)

| Data Format                |         | TC9012       | SONY      |           |           |            |
|----------------------------|---------|--------------|-----------|-----------|-----------|------------|
|                            |         | TC9012F/9243 | SONY-D7C5 | SONY-D7C6 | SONY-D7C8 | SONY-D7C13 |
| Lead code (10 μs)          | LEAD_S  | 450          | 240       | 240       | 240       | 240        |
|                            | LEAD_E  | 450          | 60        | 60        | 60        | 60         |
| Bit0 (10 μs)               | B0_L    | 56           | 60        | 60        | 60        | 60         |
|                            | B0_H    | 56           | 60        | 60        | 60        | 60         |
| Bit1 (10 μs)               | B1_L    | 56           | 120       | 120       | 120       | 120        |
|                            | B1_H    | 169          | 60        | 60        | 60        | 60         |
| Simple repeat code (10 μs) | SLEAD_S | None         | None      | None      | None      | None       |
|                            | SLEAD_E |              |           |           |           |            |
| Burst (10 μs)              |         | 56           | None      | None      | None      | None       |
| Frame length (10 μs)       |         | 10800        | 4500      | 4500      | 4500      | 4500       |
| Valid data bit             |         | 32           | 12        | 13        | 15        | 20         |

### 11.4.3.2 NEC with Simple Repeat Code

#### Frame Format

A frame in NEC with simple repeat code format consists of a start signal (lead code), a data code, and a burst signal. The start signal consists of a start code (low level) and an end code (high level). The number of valid data bits and the meaning of a specific bit in the data code depend on the specific code format, and the LSB of the data code is received first. The burst signal is used to receive the last data bit.

[Figure 11-6](#) shows the format for transmitting a single frame in NEC with simple repeat code format.

**Figure 11-6** Format for transmitting a single frame in NEC with simple repeat code format



If a complete data frame is received after a key is held down for more than one frame duration, the subsequent received data frame consists of only a simple lead code and a burst signal. The simple lead code also consists of a start code (low level) and an end code (high level). [Figure 11-7](#) shows the format for transmitting consecutive frames in NEC with simple repeat code format by holding the key down.

[Figure 11-7](#) Format for transmitting consecutive frames in NEC with simple repeat code format by holding a key down



#### Code Format

[Figure 11-8](#) shows the definitions of bit 0 and bit 1 of the NEC with simple repeat code.

**Figure 11-8** Definitions of bit 0 and bit 1 of the NEC with simple repeat code



[Figure 11-9](#) shows the code format for transmitting a single NEC with simple repeat code. [Figure 11-10](#) shows the code format for transmitting consecutive NEC with simple repeat codes by holding the key down.

**Figure 11-9** Format for transmitting an NEC with simple repeat code**Figure 11-10** Format for transmitting consecutive NEC with simple repeat codes

The pulse width of the high and low levels and the frame duration depend on specific code formats. For details, see [Table 11-5](#) to [Table 11-7](#).

The frame duration must be less than or equal to 160 ms. Otherwise, the simple lead code cannot be identified.

### 11.4.3.3 NEC with Full Repeat Code

#### Frame Format

A frame in NEC with full repeat code format consists of a start signal (lead code), a data code, and a burst signal. The start signal consists of a start code (low level) and an end code (high level). The number of valid data bits and the meaning of a specific bit in the data code depend on the specific code format, and the LSB of the data code is received first. The burst signal is used to receive the last data bit. [Figure 11-11](#) shows the format for transmitting a single frame in NEC with full repeat code format.

**Figure 11-11** Format for transmitting a single frame in NEC with full repeat code format

If a complete data frame (the first frame) is received after a key is held down for more than one frame duration, the subsequent received data frame is still a complete data frame. That is, the first frame is transmitted repeatedly based on the frame interval. [Figure 11-12](#) shows the format for transmitting consecutive frames in NEC with full repeat code format by holding a key down.



**Figure 11-12** Format for transmitting consecutive frames in NEC with full repeat code format by holding a key down



[Figure 11-7](#) and [Figure 11-12](#) show that the only difference between the NEC with simple repeat code and the NEC with full repeat code is the format of the repeat frame. For the NEC with simple repeat code, a simple lead code is transmitted; for the NEC with full repeat code, complete frames are transmitted. The repeat frame is the same as the first frame.

## Code Format

[Figure 11-13](#) shows the definitions of bit 0 and bit 1 of the NEC with full repeat code.

**Figure 11-13** Definitions of bit 0 and bit 1 of the NEC with full repeat code



[Figure 11-14](#) shows the format for transmitting a single NEC with full repeat code.

**Figure 11-14** Format for transmitting a single NEC with full repeat code



The pulse width of the high and low levels and the frame duration depend on specific code formats. For details, see [Table 11-5](#) to [Table 11-7](#).

### 11.4.3.4 TC9012

#### Frame Format



#### CAUTION

According to the TC9012 code features, the first bit of all key codes must be 1 or 0. Otherwise, unexpected frames are generated when a key is held down.

A frame in TC9012 code format consists of a start signal (lead code), a data code, and a burst signal. The start signal consists of a start code (low level) and an end code (high level). The number of valid data bits and the meaning of a specific bit in the data code depend on the specific code format, and the LSB of the data code is received first. The burst signal is used to receive the last data bit. Figure 11-15 shows the format for transmitting a single frame in TC9012 code format.

**Figure 11-15** Format for transmitting a single frame in TC9012 code format



If a complete data frame is received after a key is held down for more than one frame duration, the subsequent received data frame consists of a lead code, a data bit, and a burst signal. The lead code also consists of a start code (low level) and an end code (high level). The data bit is the inverse code of the first data bit ( $C_0$ ) received in the previous frame. Figure 11-16 shows the format for transmitting consecutive frames in TC9012 code format by holding a key down.

**Figure 11-16** Format for transmitting consecutive frames in TC9012 code format by holding a key down



## Code Format

Figure 11-17 shows the definitions of bit 0 and bit 1 of the TC9012 code.

**Figure 11-17** Definitions of bit 0 and bit 1 of the TC9012 code



Figure 11-18 shows the format for transmitting a single TC9012 code.

**Figure 11-18** Format for transmitting a single TC9012 code



Figure 11-19 shows the format for transmitting consecutive TC9012 codes when C0 is 1.

**Figure 11-19** Format for transmitting consecutive TC9012 codes when C0 is 1



Figure 11-20 shows the format for transmitting consecutive TC9012 codes when C0 is 0.

**Figure 11-20** Format for transmitting consecutive TC9012 codes when C0 is 0



Note: The pulse width of the high and low levels and the frame duration depend on specific code formats. For details, see [Table 11-5](#) to [Table 11-7](#). The frame duration must be less than or equal to 160 ms. Otherwise, the repeat frame cannot be identified.

### 11.4.3.5 SONY

#### Frame Format

A frame in SONY format consists of a start signal (lead code) and a data code. The start signal consists of a start code (low level) and an end code (high level). The number of valid data bits and the meaning of a specific bit in the data code depend on the specific code format, and the LSB of the data code is received first. Figure 11-21 shows the format for transmitting a single frame in SONY code format.

**Figure 11-21** Format for transmitting a single frame in SONY code format



If a complete data frame is received after a key is held down for more than one frame duration, the subsequent received data frame is also a complete data frame. Figure 11-22 shows the format for transmitting consecutive frames in SONY code format by holding a key down.



**Figure 11-22** Format for transmitting consecutive frames in SONY code format by holding a key down



## Bit Format

Figure 11-23 shows the definitions of bit 0 and bit 1 of the SONY code.

**Figure 11-23** Definitions of bit 0 and bit 1 of the SONY code



Note: The pulse width of the high and low levels and the frame duration depend on specific code formats. For details, see [Table 11-5](#) to [Table 11-7](#).

## 11.4.4 Operating Mode

### Soft Reset

The IR module can be separately soft-reset by setting SC\_CLKGATE\_SRST\_CTRL[ir\_srst\_req] to 1. After reset is deasserted, the configuration registers are restored to default values. Therefore, these registers must be reinitialized after reset.

### Register Configuration Instances

Figure 11-24 shows the process for initializing the IR module.

**Figure 11-24** Process for initializing the IR module

To initialize the IR module, perform the following steps:

**Step 1** Select the address space of the IR module.

**Step 2** Set [IR\\_EN](#) bit[0] to 1 to enable the IR RX module.

**Step 3** Read [IR\\_BUSY](#) to check the current status of the IR module.

- If the read value is 1, the IR module is busy. Then continue to read [IR\\_BUSY](#). Note that configuring other control registers of the IR module by using software has no effect at this time.
- If the read value is 0, the IR module is idle. Then go to step 4.

**Step 4** Configure [IR\\_CFG](#), [IR\\_LEADS](#), [IR\\_LEADE](#), [IR\\_SLEADE](#), [IR\\_B0](#), [IR\\_B1](#), and [IR\\_INT\\_MASK](#).

Note: You can update corresponding registers as required. If the registers are not updated, the original values are retained.

**Step 5** Configure [IR\\_START](#) after all IR control registers are configured. This is because [IR\\_START](#) is used to generate the start signal. If [IR\\_START](#) is configured, the IR module starts to receive infrared data based on the values of IR control registers.

----End



**Figure 11-25** Process for reading the decoded data



To read the decoded data, perform the following steps:

**Step 1** Initialize the IR module.

**Step 2** Wait in interrupt or query mode until data frames are received.

- In interrupt mode, the CPU queries `IR_INT_STATUS[intms_rcv]` when it receives an interrupt request signal from the IR module. If the read value is 1, the IR module receives a data frame. Then go to step 3. If the read value is 0, repeat step 2 to wait for an interrupt.
- In query mode, the software continuously or periodically reads `IR_INT_STATUS[intrs_rcv]`. If the read value is 1, the IR module receives a data frame. Then go to step 3. If the read value is 0, the IR module does not receive a data frame. Then repeat step 2 to continue the query.

**Step 3** Read `IR_DATAH`. Skip this step if data in a frame does not exceed 32 bits.

**Step 4** Read `IR_DATAL`.

**Step 5** Clear the RX data interrupt.

----End



## 11.4.5 Register Summary

Table 11-8 describes IR registers.

**Table 11-8** Summary of IR registers (base address: 0xF8001000)

| Offset Address | Register      | Description                                                                                                                           | Page                  |
|----------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| 0x000          | IR_EN         | IR RX enable control register                                                                                                         | <a href="#">11-49</a> |
| 0x004          | IR_CFG        | IR configuration register                                                                                                             | <a href="#">11-49</a> |
| 0x008          | IR_LEADS      | Lead code start bit margin configuration register (valid only when IR_CFG[ir_mode] is 0)                                              | <a href="#">11-51</a> |
| 0x00C          | IR_LEADE      | Lead code end bit margin configuration register (valid only when IR_CFG[ir_mode] is 0)                                                | <a href="#">11-52</a> |
| 0x010          | IR_SLEADE     | Simple lead code end bit margin configuration register (valid only when IR_CFG[ir_mode] is 0)                                         | <a href="#">11-53</a> |
| 0x014          | IR_B0         | Data 0 level judge margin configuration register (valid only when IR_CFG[ir_mode] is 0)                                               | <a href="#">11-54</a> |
| 0x018          | IR_B1         | Data 1 level judge margin configuration register (valid only when IR_CFG[ir_mode] is 0)                                               | <a href="#">11-55</a> |
| 0x01C          | IR_BUSY       | Configuration busy flag register                                                                                                      | <a href="#">11-56</a> |
| 0x020          | IR_DATAH      | Upper 16-bit IR RX decoded data register (when IR_CFG[ir_mode] is 0) or symbol FIFO symbol count register (when IR_CFG[ir_mode] is 1) | <a href="#">11-56</a> |
| 0x024          | IR_DATAL      | Lower 32-bit IR RX decoded data register (when IR_CFG[ir_mode] is 0) or IR received symbol width register (when IR_CFG[ir_mode] is 1) | <a href="#">11-57</a> |
| 0x028          | IR_INT_MASK   | IR interrupt mask register                                                                                                            | <a href="#">11-58</a> |
| 0x02C          | IR_INT_STATUS | IR interrupt status register                                                                                                          | <a href="#">11-60</a> |
| 0x030          | IR_INT_CLR    | IR interrupt clear register                                                                                                           | <a href="#">11-62</a> |
| 0x034          | IR_START      | IR start configuration register                                                                                                       | <a href="#">11-64</a> |



## 11.4.6 Register Description

### IR\_EN

IR\_EN is an IR RX enable control register.



#### CAUTION

Before configuring other registers, set IR\_EN[ir\_en] to 1 by using software. Otherwise, configuring other registers has no effect. When IR\_EN[ir\_en] is 0, other registers are read-only and the read values are their reset values.

|        | Offset Address |          |    |                                           |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
|        | 0x000          |          |    |                                           |    |    |    |    |    |    |    |    |    |    |    |    | IR_EN         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Bit    | 31             | 30       | 29 | 28                                        | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Name   | reserved       |          |    |                                           |    |    |    |    |    |    |    |    |    |    |    |    | ir_en         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    | Description                               |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| [31:1] | -              | reserved |    | Reserved                                  |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| [0]    | RW             | ir_en    |    | IR RX enable<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

### IR\_CFG

IR\_CFG is an IR configuration register.



#### CAUTION

Before setting this register, ensure that IR\_BUSY[ir\_busy] is set to 0 and IR\_EN[ir\_en] is set to 1. Otherwise, the original value is retained after setting.

The reference clock frequency supported by the IR module ranges from 1 MHz to 128 MHz. The following describes the relationship between the frequency and the clock divider ir\_freq:

- When the reference clock frequency is 1 MHz, ir\_freq must be set to 0x00.
- When the reference clock frequency is 128 MHz, ir\_freq must be set to 0x7F.



When the frequency of the IR reference clock ranging from 1 MHz to 128 MHz is not an integer, the clock divider is selected based on the rounded reference clock frequency. For example, if the reference clock frequency is 12.1 MHz, the clock divider is 0x0B; if the reference clock frequency is 12.8 MHz, the clock divider is 0x0C.

The following describes the relationship between the frequency offset and the count deviation. If the base frequency is  $f$  and the frequency variation is  $D_f$ , the frequency offset ratio is  $D_f/f$ . If the count deviation of the counter is  $D_{cnt}$ , and the judge level width is  $s$  (in  $\mu s$ ), the count deviation  $D_{cnt}$  is calculated as follows:  $D_{cnt} = 0.1 \times s \times \text{ratio}$ . Therefore, when the clock has frequency offset, the valid range of the parameter value needs to be shifted. If the frequency increases, the corresponding margin range is changed to  $[\min + D_{cnt}, \max + D_{cnt}]$ , where  $\min$  and  $\max$  indicate the margins without frequency offset. If the frequency decreases, the offset range is changed to  $[\min - D_{cnt}, \max - D_{cnt}]$ . Take the margin of the start bit in the lead code as an example. If the base frequency is 100 MHz, and the frequency increases by 0.1 MHz, the ratio is 0.001 (0.1/100). If  $s$  is 9000  $\mu s$ ,  $D_{cnt}$  is calculated as follows:  $D_{cnt} = 0.1 \times 9000 \times 0.001 = 1$ . In this case, the margin range of `ir_leads` must be changed to [0x033D, 0x3CD].

|         | Offset Address                                                                                      | Register Name      | Total Reset Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |         |
|---------|-----------------------------------------------------------------------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | IR_CFG             | 0x3E80_1F0B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |         |
| Name    | ir_max_level_width                                                                                  | ir_format          | ir_bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ir_mode | ir_freq |
| Reset   | 0 0 1 1   1 1 1 0   1 0 0 0   0 0 0 0   0 0 0 1   1 1 1 1   0 0 0 0   1 0 1 1                       |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |         |
| Bits    | Access                                                                                              | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |         |
| [31:16] | RW                                                                                                  | ir_max_level_width | Invalid when IR_CFG[ir_mode] is 0<br>Maximum level width (in 10 $\mu s$ ) of a symbol when IR_CFG[ir_mode] is 1. This width identifies the end of a symbol stream.                                                                                                                                                                                                                                                                                                                                                                              |         |         |
| [15:14] | RW                                                                                                  | ir_format          | Data code format when IR_CFG[ir_mode] is 0<br>00: NEC with simple repeat code<br>01: TC9012 code<br>10: NEC with full repeat code<br>11: SONY code<br>For details about the relationship between code types and code formats, see <a href="#">Table 11-5</a> to <a href="#">Table 11-7</a> .<br>Symbol format when IR_CFG[ir_mode] is 1<br>Bit[15]: reserved<br>Bit[14]:<br>0: The symbol is from low to high, and the symbol stream ends at the high level.<br>1: The symbol is from high to low, and the symbol stream ends at the low level. |         |         |



|        |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:8] | RW | ir_bits | Number of data bits in a frame when IR_CFG[ir_mode] is 0<br>0x00–0x2F: correspond to bit 1 to bit 48 in a frame respectively<br>0x30–0x3F: reserved<br><br>If ir_bits is set to a value ranging from 0x30 to 0x3F by using software, the setting has no effect and the original value is retained.<br><br>Symbol RX interrupt threshold when IR_CFG[ir_mode] is 1<br>Bit[13:8]: 0x0–0x3F. 0x0 indicates that an interrupt is reported when there is at least one symbol in the FIFO, 0x3F indicates that an interrupt is reported when there are at least 64 symbols in the FIFO, and so on. |
| [7]    | RW | ir_mode | IR operating mode<br>0: The decoded complete data frames are output.<br>1: Only the symbol width is output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [6:0]  | RW | ir_freq | Working clock divider<br>0x00–0x7F correspond to the clock divider 1–128 respectively.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

## IR\_LEADS

IR\_LEADS is a lead code start bit margin configuration register (valid only when [IR\\_CFG\[ir\\_mode\]](#) is 0).



### CAUTION

Before setting this register, ensure that [IR\\_BUSY\[ir\\_busy\]](#) is set to 0 and [IR\\_EN\[ir\\_en\]](#) is set to 1. Otherwise, the original value is retained after setting.

The margin must be considered based on the typical value of the specific code type for accurately determining the start bit of the lead code. For details about the typical values of specified code types, see the values of LEAD\_S in [Table 11-5](#) to [Table 11-7](#).

- For the pulse width whose typical value is greater than or equal to 400 (10  $\mu$ s precision), the recommended margin is 8% of the typical value. For example, if the typical value of LEAD\_S for D6121 is 900, the value of cnt\_leads\_min is 0x33C ( $900 \times 92\% = 828$ ), and the value of cnt\_leads\_max is 0x3CC ( $900 \times 108\% = 972$ ).
- For the pulse width whose typical value is less than 400 (10  $\mu$ s precision), the recommended margin is 20% of the typical value. For example, if the typical value of LEAD\_S for SONY-D7C5 is 240, the value of cnt\_leads\_min is 0xC0 ( $240 \times 80\% = 192$ ), and the value of cnt\_leads\_max is 0x120 ( $240 \times 120\% = 288$ ).

The basic configuration principles are as follows: cnt\_leads\_max is greater than or equal to cnt\_leads\_min, and cnt\_leads\_min is greater than cnt0\_b\_max and cnt1\_b\_max.



| Offset Address |          |               |    |                                                                                |    |    |    |    |               |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |               |   |   |   |   |   |   |   |
|----------------|----------|---------------|----|--------------------------------------------------------------------------------|----|----|----|----|---------------|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|---------------|---|---|---|---|---|---|---|
| 0x008          |          |               |    |                                                                                |    |    |    |    |               |    |    |    |    |    |    | IR_LEADS      |          |    |    |    |    |    |   | 0x033C_03CC       |               |   |   |   |   |   |   |   |
| Bit            | 31       | 30            | 29 | 28                                                                             | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |               |    |                                                                                |    |    |    |    | cnt_leads_min |    |    |    |    |    |    |               | reserved |    |    |    |    |    |   |                   | cnt_leads_max |   |   |   |   |   |   |   |
| Reset          | 0        | 0             | 0  | 0                                                                              | 0  | 0  | 1  | 1  | 0             | 0  | 1  | 1  | 1  | 1  | 0  | 0             | 0        | 0  | 0  | 0  | 0  | 1  | 1 | 1                 | 1             | 0 | 0 | 1 | 1 | 0 | 0 |   |
| Bits           | Access   | Name          |    | Description                                                                    |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [31:26]        | -        | reserved      |    | Reserved                                                                       |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [25:16]        | RW       | cnt_leads_min |    | Minimum pulse width of the start bit of the lead code<br>0x000–0x007: reserved |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [15:10]        | -        | reserved      |    | Reserved                                                                       |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [9:0]          | RW       | cnt_leads_max |    | Maximum pulse width of the start bit of the lead code<br>0x000–0x007: reserved |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |

## IR\_LEADE

IR\_LEADE is a lead code end bit margin configuration register (valid only when [IR\\_CFG\[ir\\_mode\]](#) is 0).



### CAUTION

- Before configuring this register, ensure that IR\_BUSY[ir\_busy] is set to 0 and IR\_EN[ir\_en] is set to 1. Otherwise, the original value is retained after configuration.
- For the NEC with simple repeat codes, the margins of cnt\_sleade and cnt\_leade cannot overlap. Otherwise, when the actual count value falls within the overlap range, the simple lead code cannot be identified. As a result, a frame format error occurs.

The margin must be considered based on the typical value of the specific code type for accurately determining the end bit of the lead code. The margin is about 8% of the typical value. For details about the typical values of specific code types, see the values of LEAD\_E in [Table 11-5](#) to [Table 11-7](#).

- For the pulse width whose typical value is greater than or equal to 400 (10 µs precision), the recommended margin is 8% of the typical value. For example, if the typical value of LEAD\_E for D6121 is 450, the value of cnt\_leade\_min is 0x19E ( $450 \times 92\% = 414$ ), and the value of cnt\_leade\_max is 0x1E6 ( $450 \times 108\% = 486$ ).
- For the pulse width whose typical value is less than 400 (10 µs precision), the recommended margin is 20% of the typical value. For example, if the typical value of LEAD\_E for SONY-D7C5 is 60, the value of cnt\_leade\_min is 0x030 ( $60 \times 80\% = 48$ ), and the value of cnt\_leade\_max is 0x048 ( $60 \times 120\% = 72$ ).

The basic configuration principle is that cnt\_leade\_max must be greater than or equal to cnt\_leade\_min.



| Offset Address |          |               |    |                                                                              |    |    |    |    |               |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |               |   |   |   |   |   |   |   |
|----------------|----------|---------------|----|------------------------------------------------------------------------------|----|----|----|----|---------------|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|---------------|---|---|---|---|---|---|---|
| 0x00C          |          |               |    |                                                                              |    |    |    |    |               |    |    |    |    |    |    | IR_LEADE      |          |    |    |    |    |    |   | 0x019E_01E6       |               |   |   |   |   |   |   |   |
| Bit            | 31       | 30            | 29 | 28                                                                           | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |               |    |                                                                              |    |    |    |    | cnt_leade_min |    |    |    |    |    |    |               | reserved |    |    |    |    |    |   |                   | cnt_leade_max |   |   |   |   |   |   |   |
| Reset          | 0        | 0             | 0  | 0                                                                            | 0  | 0  | 0  | 1  | 1             | 0  | 0  | 1  | 1  | 1  | 1  | 0             | 0        | 0  | 0  | 0  | 0  | 0  | 1 | 1                 | 1             | 1 | 0 | 0 | 1 | 1 | 0 |   |
| Bits           | Access   | Name          |    | Description                                                                  |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [31:25]        | -        | reserved      |    | Reserved                                                                     |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [24:16]        | RW       | cnt_leade_min |    | Minimum pulse width of the end bit of the lead code<br>0x000–0x007: reserved |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [15:9]         | -        | reserved      |    | Reserved                                                                     |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |
| [8:0]          | RW       | cnt_leade_max |    | Maximum pulse width of the end bit of the lead code<br>0x000–0x007: reserved |    |    |    |    |               |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |               |   |   |   |   |   |   |   |

## IR\_SLEADE

IR\_SLEADE is a simple lead code end bit margin configuration register (valid only when [IR\\_CFG\[ir\\_mode\]](#) is 0).



### CAUTION

- Before setting this register, ensure that IR\_BUSY[ir\_busy] is set to 0 and IR\_EN[ir\_en] is set to 1. Otherwise, the original value is retained after setting.
- For the NEC with simple repeat codes, the margins of cnt\_sleade and cnt\_leade cannot overlap. Otherwise, when the actual count value falls within the overlap range, the simple lead code cannot be identified. As a result, a frame format error occurs.
- This register needs to be configured only for the NEC with simple repeat code.

The margin must be considered based on the typical value of the specific code type for accurately determining the end bit of the simple lead code.

For details about the typical values of specific code types, see the values of SLEAD\_E in [Table 11-5](#) to [Table 11-7](#).

- For a pulse width whose typical value is greater than or equal to 225 (10 µs precision), the recommended margin is 8% of the typical value. For example, if the typical value of SLEAD\_E for D6121 is 225, the value of cnt\_sleade\_min is 0xCF (225 x 92% = 207), and the value of cnt\_sleade\_max is 0xF3 (225 x 108% = 243). For a pulse width whose typical value is less than 225 (10 µs precision), the recommended margin is 20% of the typical value. For example, if the typical value of SLEAD\_E for a code is 60, the value of cnt\_sleade\_min is 0x030 (60 x 80% = 48), and the value of cnt\_sleade\_max is 0x048 (60 x 120% = 72).



The basic configuration principle is that cnt\_sleade\_max must be greater than or equal to cnt\_sleade\_min.

| Offset Address |          |                |    |    |    |                                                                                       |    |    |                |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |                |   |   |   |   |   |   |   |
|----------------|----------|----------------|----|----|----|---------------------------------------------------------------------------------------|----|----|----------------|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|----------------|---|---|---|---|---|---|---|
| 0x010          |          |                |    |    |    |                                                                                       |    |    |                |    |    |    |    |    |    | IR_SLEADE     |          |    |    |    |    |    |   | 0x00CF_00F3       |                |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28 | 27 | 26                                                                                    | 25 | 24 | 23             | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |    |    |                                                                                       |    |    | cnt_sleade_min |    |    |    |    |    |    |               | reserved |    |    |    |    |    |   |                   | cnt_sleade_max |   |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0  | 0  | 0  | 0                                                                                     | 0  | 0  | 1              | 1  | 0  | 0  | 1  | 1  | 1  | 1             | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 1              | 1 | 1 | 1 | 0 | 0 | 1 | 1 |
| Bits           | Access   | Name           |    |    |    | Description                                                                           |    |    |                |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |                |   |   |   |   |   |   |   |
| [31:25]        | -        | reserved       |    |    |    | Reserved                                                                              |    |    |                |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |                |   |   |   |   |   |   |   |
| [24:16]        | RW       | cnt_sleade_min |    |    |    | Minimum pulse width of the end bit of the simple lead code<br>0x000–0x007: reserved   |    |    |                |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |                |   |   |   |   |   |   |   |
| [15:9]         | -        | reserved       |    |    |    | Reserved                                                                              |    |    |                |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |                |   |   |   |   |   |   |   |
| [8:0]          | RW       | cnt_sleade_max |    |    |    | Maximum pulse width of the start bit of the simple lead code<br>0x000–0x007: reserved |    |    |                |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |                |   |   |   |   |   |   |   |

## IR\_B0

IR\_B0 is a data 0 level judge margin configuration register (valid only when IR\_CFG[ir\_mode] is 0).



### CAUTION

- Before setting this register, ensure that IR\_BUSY[ir\_busy] is set to 0 and set IR\_EN[ir\_en] is set to 1. Otherwise, the original value is retained after setting.
- The level judge margin ranges for bit 0 and bit 1 of the four types of codes cannot overlap. Otherwise, when the actual count value falls within the overlap range, bit 1 cannot be identified and is regarded as bit 0 by mistake.

The margin must be considered based on the typical value of the specific code type for accurately determining bit 0. The margin is about 20% of the typical value.

- For details about the typical values of the NEC with simple repeat code, NEC with simple repeat code, and TC9012 code, see the values of B0\_H in [Table 11-5](#) to [Table 11-7](#). For example, if the typical value of B0\_H for D6121 is 56 (10 µs precision), cnt0\_b\_min is 0x2D ( $56 \times 80\% = 45$ ), and cnt0\_b\_max is 0x43 ( $56 \times 120\% = 67$ ).
- For details about the typical values of SONY codes, see the values of B0\_L in [Table 11-5](#) to [Table 11-7](#). For example, if the typical value of B0\_L for SONY-D7C5 is 60 (10 µs precision), cnt0\_b\_min is 0x30 ( $60 \times 80\% = 48$ ), and cnt0\_b\_max is 0x48 ( $60 \times 120\% = 72$ ).



The basic configuration principle is that cnt0\_b\_max must be greater than or equal to cnt0\_b\_min.

| Offset Address |          |            |    |    |                                                                                 |    |    |    |            |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |            |   |   |   |   |   |   |   |
|----------------|----------|------------|----|----|---------------------------------------------------------------------------------|----|----|----|------------|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|------------|---|---|---|---|---|---|---|
| 0x014          |          |            |    |    |                                                                                 |    |    |    |            |    |    |    |    |    |    | IR_B0         |          |    |    |    |    |    |   | 0x002D_0043       |            |   |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27                                                                              | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    |                                                                                 |    |    |    | cnt0_b_min |    |    |    |    |    |    |               | reserved |    |    |    |    |    |   |                   | cnt0_b_max |   |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0                                                                               | 0  | 0  | 0  | 0          | 0  | 1  | 0  | 1  | 1  | 0  | 1             | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0          | 0 | 1 | 0 | 0 | 0 | 1 | 1 |
| Bits           | Access   | Name       |    |    | Description                                                                     |    |    |    |            |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |            |   |   |   |   |   |   |   |
| [31:25]        | -        | reserved   |    |    | Reserved                                                                        |    |    |    |            |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |            |   |   |   |   |   |   |   |
| [24:16]        | RW       | cnt0_b_min |    |    | Minimum pulse width of the level for determining bit 0<br>0x000–0x007: reserved |    |    |    |            |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |            |   |   |   |   |   |   |   |
| [15:9]         | -        | reserved   |    |    | Reserved                                                                        |    |    |    |            |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |            |   |   |   |   |   |   |   |
| [8:0]          | RW       | cnt0_b_max |    |    | Maximum pulse width of the level for determining bit 0<br>0x000–0x007: reserved |    |    |    |            |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |            |   |   |   |   |   |   |   |

## IR\_B1

IR\_B1 is a data 1 judge level margin configuration register (valid only when IR\_CFG[ir\_mode] is 0).



### CAUTION

- Before configuring this register, ensure that IR\_BUSY[ir\_busy] is set to 0 and IR\_EN[ir\_en] is set to 1. Otherwise, the original value is retained after configuration.
- The level judge margin ranges for bit 0 and bit 1 of the four types of codes cannot overlap. Otherwise, when the actual count value falls within the overlap range, bit 1 cannot be identified and is regarded as bit 0 by mistake.

The margin must be considered based on the typical value of the specific code type for accurately determining bit 1. The margin is about 20% of the typical value.

- For details about the typical values of the NEC with simple repeat code, NEC with simple repeat code, and TC9012 code, see the values of B1\_H in [Table 11-5](#) to [Table 11-7](#). For example, if the typical value of B1\_H for D6121 is 169 (10 µs precision), cnt1\_b\_min is 0x87 ( $169 \times 80\% = 135$ ), and cnt1\_b\_max is 0xCB ( $169 \times 120\% = 203$ ).
- For details about the typical values of SONY codes, see the values of B1\_L in [Table 11-5](#) to [Table 11-7](#). For example, if the typical value of B1\_L for SONY-D7C5 is 120 (10 µs precision), cnt1\_b\_min is 0x60 ( $120 \times 80\% = 96$ ), and cnt1\_b\_max is 0x90 ( $120 \times 120\% = 144$ ).

The basic configuration principle is that cnt1\_b\_max must be greater than or equal to cnt1\_b\_min.



| Offset Address |          |            |    |    |                                                                                 |    |    | Register Name |    |    |    |    |          |    |    | Total Reset Value |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|------------|----|----|---------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----------|----|----|-------------------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x018          |          |            |    |    |                                                                                 |    |    | IR_B1         |    |    |    |    |          |    |    | 0x0087_00CB       |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27                                                                              | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19       | 18 | 17 | 16                | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    | cnt1_b_min                                                                      |    |    |               |    |    |    |    | reserved |    |    |                   | cnt1_b_max |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0                                                                               | 0  | 0  | 0             | 1  | 0  | 0  | 0  | 0        | 1  | 1  | 1                 | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |   |
| Bits           | Access   | Name       |    |    | Description                                                                     |    |    |               |    |    |    |    |          |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:25]        | -        | reserved   |    |    | Reserved                                                                        |    |    |               |    |    |    |    |          |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [24:16]        | RW       | cnt1_b_min |    |    | Minimum pulse width of the level for determining bit 1<br>0x000–0x007: reserved |    |    |               |    |    |    |    |          |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:9]         | -        | reserved   |    |    | Reserved                                                                        |    |    |               |    |    |    |    |          |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [8:0]          | RW       | cnt1_b_max |    |    | Maximum pulse width of the level for determining bit 1<br>0x000–0x007: reserved |    |    |               |    |    |    |    |          |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## **IR\_BUSY**

**IR\_BUSY** is a configuration busy flag register.

IR\_DATAH

IR\_DATAH is an upper 16-bit IR RX decoded data register (when [IR\\_CFG\[ir\\_mode\]](#) is 0) or symbol FIFO symbol count register (when [IR\\_CFG\[ir\\_mode\]](#) is 1).

When `IR_CFG[ir_mode]` is set to 0, `IR_DATAH` receives the upper 16 bits of the decoded data, whereas `IR_DATAL` receives the lower 32 bits of the decoded data. The valid data bits



depend on the number of valid data bits in a frame of specific code. For details, see the valid data bits in [Table 11-5](#) to [Table 11-7](#).

Data is stored in [IR\\_DATAL](#) and then [IR\\_DATAH](#) from LSB to MSB. That is, after [IR\\_DATAL](#) is full, the remaining data is stored in [IR\\_DATAH](#). The unused upper bits are reserved. Software must read [IR\\_DATAH](#) before [IR\\_DATAL](#).

When [IR\\_CFG\[ir\\_mode\]](#) is 1, hardware receives all data bits without considering the definition of each data bit. Then software processes the data bits in a unified manner.

|         | Offset Address                                                                                      | Register Name | Total Reset Value                                                                                                                                                                                                                                                |  |          |  |  |  |
|---------|-----------------------------------------------------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|----------|--|--|--|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | IR_DATAH      | 0x0000_0000                                                                                                                                                                                                                                                      |  |          |  |  |  |
| Name    | reserved                                                                                            |               |                                                                                                                                                                                                                                                                  |  | ir_datah |  |  |  |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |               |                                                                                                                                                                                                                                                                  |  |          |  |  |  |
| Bits    | Access                                                                                              | Name          | Description                                                                                                                                                                                                                                                      |  |          |  |  |  |
| [31:16] | -                                                                                                   | reserved      | Reserved                                                                                                                                                                                                                                                         |  |          |  |  |  |
| [15:0]  | RO                                                                                                  | ir_datah      | Upper 16 bits of the decoded data received by the IR module when <a href="#">IR_CFG[ir_mode]</a> is 0<br>Number of symbols in the symbol FIFO when <a href="#">IR_CFG[ir_mode]</a> is 1<br>Bit[15:7]: reserved<br>Bit[6:0]: number of symbols in the symbol FIFO |  |          |  |  |  |

## IR\_DATAL

[IR\\_DATAL](#) is a lower 32-bit IR RX decoded data register (when [IR\\_CFG\[ir\\_mode\]](#) is 0) or IR received symbol width register (when [IR\\_CFG\[ir\\_mode\]](#) is 1).



| Offset Address |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x024          |          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    | IR_DATAL      |    |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | ir_datal |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:0]         | RO       | ir_datal | <p>Lower 32 bits of the decoded data received by the IR module when <a href="#">IR_CFG[ir_mode]</a> is 0</p> <p>Width of the symbol received by the IR module when <a href="#">IR_CFG[ir_mode]</a> is 1</p> <p>Bit[31:16]:</p> <p>When the symbol is low and then high, these bits indicate the high-level width (in 10 µs) of the symbol received by the IR module.</p> <p>When the symbol is high and then low, these bits indicate the low-level width (in 10 µs) of the symbol received by the IR module.</p> <p>Bit[15:0]:</p> <p>When the symbol is low and then high, these bits indicate the low-level width (in 10 µs) of the symbol received by the IR module.</p> <p>When the symbol is high and then low, these bits indicate the high-level width (in 10 µs) of the symbol received by the IR module.</p> |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## IR\_INT\_MASK

IR\_INT\_MASK is an IR interrupt mask register.



### CAUTION

- Before setting this register, ensure that [IR\\_EN\[ir\\_en\]](#) is set to 1. Otherwise, the original value is retained after setting.
- If all interrupts are masked, the IR wakeup function is unavailable.
- When [IR\\_CFG\[ir\\_mode\]](#) is 0, IR\_INT\_MASK bit[3:0] are valid; when [IR\\_CFG\[ir\\_mode\]](#) is 1, IR\_INT\_MASK bit[18:16] are valid.

The following describes related interrupts:

- RX data overflow interrupt  
If the CPU does not fetch the current frame in time and the subsequent frame is received, the subsequent frame overwrites the current frame, and a raw RX data overflow interrupt is reported.
- RX data frame format error interrupt



If the received data frame is incomplete or the data pulse width does not fall within the margin range, a raw RX frame format error interrupt is reported.

- Data frame RX interrupt

When a complete frame is received, a raw data frame RX interrupt is reported.

- Key release detection interrupt

For the NEC with simple repeat code and TC9012 code data formats, if the start sync code is not detected again within 160 ms after the previous start sync code is detected, or a valid data frame rather than a simple lead code is detected, a raw key release detection interrupt is reported. The key release detection interrupt is not supported for the NEC with full repeat code and the SONY code.

- RX symbol overflow interrupt

If the symbol FIFO is full because the CPU does not fetch the data in time and the subsequent symbol is already received, a raw RX symbol overflow interrupt is reported.

- Symbol RX interrupt

If a complete symbol is received and the number of symbols in the symbol FIFO is above the threshold specified in [IR\\_CFG\[ir\\_bits\]](#), a raw symbol RX interrupt is reported.

- Symbol timeout interrupt

If no symbol is received during the period configured in [IR\\_CFG\[ir\\_max\\_level\\_width\]](#) after a valid symbol is received, a raw symbol timeout interrupt is reported.

Hardware does not identify the interrupt priority. An interrupt is generated if one or more masked interrupt sources are valid.

|         | Offset Address 0x028 |                               |    |    |                                                                                                        |    |    |    |    |    |    |    |    |    |    |    | Register Name IR_INT_MASK |    |    |    |    |    |   |   | Total Reset Value 0x0000_0000 |   |   |   |                               |   |   |   |
|---------|----------------------|-------------------------------|----|----|--------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------|----|----|----|----|----|---|---|-------------------------------|---|---|---|-------------------------------|---|---|---|
| Bit     | 31                   | 30                            | 29 | 28 | 27                                                                                                     | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                             | 6 | 5 | 4 | 3                             | 2 | 1 | 0 |
| Name    | reserved             |                               |    |    |                                                                                                        |    |    |    |    |    |    |    |    |    |    |    | reserved                  |    |    |    |    |    |   |   | <a href="#">intm_release</a>  |   |   |   | <a href="#">intm_overflow</a> |   |   |   |
| Reset   | 0                    | 0                             | 0  | 0  | 0                                                                                                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                             | 0 | 0 | 0 | 0                             | 0 |   |   |
| Bits    | Access               | Name                          |    |    | Description                                                                                            |    |    |    |    |    |    |    |    |    |    |    |                           |    |    |    |    |    |   |   |                               |   |   |   |                               |   |   |   |
| [31:19] | -                    | reserved                      |    |    | Reserved                                                                                               |    |    |    |    |    |    |    |    |    |    |    |                           |    |    |    |    |    |   |   |                               |   |   |   |                               |   |   |   |
| [18]    | RW                   | <a href="#">intm_overrun</a>  |    |    | Symbol overflow interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 1<br>0: not masked<br>1: masked |    |    |    |    |    |    |    |    |    |    |    |                           |    |    |    |    |    |   |   |                               |   |   |   |                               |   |   |   |
| [17]    | RW                   | <a href="#">intm_time_out</a> |    |    | Symbol timeout interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 1<br>0: not masked<br>1: masked  |    |    |    |    |    |    |    |    |    |    |    |                           |    |    |    |    |    |   |   |                               |   |   |   |                               |   |   |   |



|        |    |               |                                                                                                                   |
|--------|----|---------------|-------------------------------------------------------------------------------------------------------------------|
| [16]   | RW | intm_symb_rcv | <i>n</i> symbol RX interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 1<br>0: not masked<br>1: masked         |
| [15:4] | -  | reserved      | Reserved                                                                                                          |
| [3]    | RW | intm_release  | Key release interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 0<br>0: not masked<br>1: masked                |
| [2]    | RW | intm_overflow | RX data overflow interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 0<br>0: not masked<br>1: masked           |
| [1]    | RW | intm_framerr  | RX data frame format error interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 0<br>0: not masked<br>1: masked |
| [0]    | RW | intm_rcv      | Data frame RX interrupt mask when <a href="#">IR_CFG[ir_mode]</a> is 0<br>0: not masked<br>1: masked              |

## IR\_INT\_STATUS

IR\_INT\_STATUS is an IR interrupt status register.



### CAUTION

- When [IR\\_CFG\[ir\\_mode\]](#) is 0, IR\_INT\_STATUS bit[3:0] and IR\_INT\_STATUS bit[19:16] are valid.
- When [IR\\_CFG\[ir\\_mode\]](#) is 1, IR\_INT\_STATUS bit[10:8] and IR\_INT\_STATUS bit[26:24] are valid.



| Offset Address |          |                |    |    |                                                                                                                                                |                |                |          |    |    |    | Register Name |                |               |           |          |    |    |    |               |                |                |          | Total Reset Value |   |   |               |                |               |           |   |   |  |  |  |
|----------------|----------|----------------|----|----|------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------|----|----|----|---------------|----------------|---------------|-----------|----------|----|----|----|---------------|----------------|----------------|----------|-------------------|---|---|---------------|----------------|---------------|-----------|---|---|--|--|--|
| 0x02C          |          |                |    |    |                                                                                                                                                |                |                |          |    |    |    | IR_INT_STATUS |                |               |           |          |    |    |    |               |                |                |          | 0x0000_0000       |   |   |               |                |               |           |   |   |  |  |  |
| Bit            | 31       | 30             | 29 | 28 | 27                                                                                                                                             | 26             | 25             | 24       | 23 | 22 | 21 | 20            | 19             | 18            | 17        | 16       | 15 | 14 | 13 | 12            | 11             | 10             | 9        | 8                 | 7 | 6 | 5             | 4              | 3             | 2         | 1 | 0 |  |  |  |
| Name           | reserved |                |    |    | intms_overrun                                                                                                                                  | intms_time_out | intms_symb_rcv | reserved |    |    |    | intms_release | intms_overflow | intms_framerr | intms_rcv | reserved |    |    |    | intrs_overrun | intrs_time_out | intrs_symb_rcv | reserved |                   |   |   | intrs_release | intrs_overflow | intrs_framerr | intrs_rcv |   |   |  |  |  |
| Reset          | 0        | 0              | 0  | 0  | 0                                                                                                                                              | 0              | 0              | 0        | 0  | 0  | 0  | 0             | 0              | 0             | 0         | 0        | 0  | 0  | 0  | 0             | 0              | 0              | 0        | 0                 | 0 | 0 | 0             | 0              | 0             | 0         |   |   |  |  |  |
| Bits           | Access   | Name           |    |    | Description                                                                                                                                    |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [31:27]        | -        | reserved       |    |    | Reserved                                                                                                                                       |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [26]           | RO       | intms_overrun  |    |    | Masked symbol overflow interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.            |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [25]           | RO       | intms_time_out |    |    | Masked symbol timeout interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [24]           | RO       | intms_symb_rcv |    |    | Masked symbol RX interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.                  |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [23:20]        | -        | reserved       |    |    | Reserved                                                                                                                                       |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [19]           | RO       | intms_release  |    |    | Masked key release interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.                |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [18]           | RO       | intms_overflow |    |    | Masked RX data overflow interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.           |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |
| [17]           | RO       | intms_framerr  |    |    | Masked RX data frame format error interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated. |                |                |          |    |    |    |               |                |               |           |          |    |    |    |               |                |                |          |                   |   |   |               |                |               |           |   |   |  |  |  |



|         |    |                |                                                                                                                                             |
|---------|----|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | RO | intms_rcv      | Masked data frame RX interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.           |
| [15:11] | -  | reserved       | Reserved                                                                                                                                    |
| [10]    | RO | intrs_overrun  | Raw symbol overflow interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.            |
| [9]     | RO | intrs_time_out | Raw symbol timeout interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.             |
| [8]     | RO | intrs_symb_rcv | Raw symbol RX interrupt status when IR_CFG[ir_mode] is 1<br>0: No interrupt is generated.<br>1: An interrupt is generated.                  |
| [7:4]   | -  | reserved       | Reserved                                                                                                                                    |
| [3]     | RO | intrs_release  | Raw key release interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.                |
| [2]     | RO | intrs_overflow | Raw RX data overflow interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.           |
| [1]     | RO | intrs_framerr  | Raw RX data frame format error interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [0]     | RO | intrs_rcv      | Raw data frame RX interrupt status when IR_CFG[ir_mode] is 0<br>0: No interrupt is generated.<br>1: An interrupt is generated.              |

## IR\_INT\_CLR

IR\_INT\_CLR is an IR interrupt clear register.



### CAUTION

- When [IR\\_CFG\[ir\\_mode\]](#) is 0, IR\_INT\_CLR bit[3:0] are valid.



- When IR\_CFG[ir\_mode] is 1, IR\_INT\_CLR bit[18:16] are valid.

| Offset Address |                                                                                                     | Register Name |                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x030                                                                                               | IR_INT_CLR    |                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0x0000_0000       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 |               |                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |               |                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                                              | Name          | Description                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:19]        | -                                                                                                   | reserved      | Reserved                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [18]           | WC                                                                                                  | intc_overrun  | Symbol overflow interrupt clear when IR_CFG[ir_mode] is 1<br>0: not cleared<br>1: cleared               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [17]           | WC                                                                                                  | intc_time_out | Symbol timeout interrupt clear when IR_CFG[ir_mode] is 1<br>0: not cleared<br>1: cleared                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [16]           | WC                                                                                                  | intc_symb_rcv | Symbol RX interrupt clear when IR_CFG[ir_mode] is 1<br>0: not cleared<br>1: cleared                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [15:4]         | -                                                                                                   | reserved      | Reserved                                                                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [3]            | WC                                                                                                  | intc_release  | Key release interrupt clear when IR_CFG[ir_mode] is 1<br>0: not cleared<br>1: cleared                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [2]            | WC                                                                                                  | intc_overflow | RX data overflow interrupt clear when IR_CFG[ir_mode] is 0<br>0: not cleared<br>1: cleared              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [1]            | WC                                                                                                  | intc_framerr  | RX data frame format error interrupt clear when<br>IR_CFG[ir_mode] is 0<br>0: not cleared<br>1: cleared |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



|     |    |          |                                                                                                                                                                                                                                                 |
|-----|----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | WC | intc_rcv | Data frame RX interrupt clear when IR_CFG[ir_mode] is 0<br>0: not cleared<br>1: cleared<br><br>If software writes 1 to the bit without reading data from IR_DATA after a data frame RX interrupt is generated, the interrupt cannot be cleared. |
|-----|----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## IR\_START

IR\_START is an IR start configuration register.

After other registers are configured, the IR module can be started when any value is written to the corresponding address for IR\_START.

|        | Offset Address 0x034 |          |    |    |                                 |    |    |    |    |    |    |    |    |    |    |    | Register Name IR_START |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   | Total Reset Value 0x0000_0000 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------------|----------|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit    | 31                   | 30       | 29 | 28 | 27                              | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | reserved             |          |    |    |                                 |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   | ir_start |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0                    | 0        | 0  | 0  | 0                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 | 0 |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access               | Name     |    |    | Description                     |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:1] | -                    | reserved |    |    | Reserved                        |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [0]    | WO                   | ir_start |    |    | IR start configuration register |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## 11.5 LED

### 11.5.1 Overview

The LED module supports only the CT1642 chip and provides the following functions:

- LED display control. The LED module receives the data to be displayed from the CPU over the APB and transmits the data and CSs to the CT1642 chip in serial mode for display.
- Only 8 x 1 keypad scanning

The working reference clock of the LED module is 24 MHz.

### 11.5.2 Function Description

The LED module has the following features:



- Integrates an APB slave interface for supporting standard APB operations.
- Supports synchronous dynamic display of a maximum of four LEDs.
- Supports the configurable refresh rate.
- Supports blinking through hardware at a configurable blinking frequency.
- Connects to the CT1642 control chip.
- Implements 8 x 1 matrix keypad scanning.
- Soft-resets the LEDC. The reset signal can be controlled by configuring SC\_CLKGATE\_SRST\_CTRL[led\_srst\_req].

## 11.5.3 Operating Mode

### 11.5.3.1 Output Timing of the LED Module

Figure 11-26 shows the output timing of the LED module. LedData and LedClk compose serial synchronous data, which is provided for the CT1642 interface. The CT1642 chip samples LedData at the LedClk rising edge. After LedData is sampled for 18 clock cycles, LedClk is forced to high for a clock cycle. When the CT1642 chip samples a LedData rising edge, it latches the previously sampled 18 data segments, and then LedClk is forced to low for a clock cycle. When CT1642 chip samples a LedData rising edge again, it transmits the latched data.

The 18 data segments include four CSs, six useless signals, and eight LedData display data segments or KeyData scanning signals. The four CSs are valid alternatively. When a CS is valid, the transmitted LedData is the LED display data corresponding to the CS. The CSs become invalid after they are valid alternatively. In this case, no LED is selected, and the transmitted data is the key scanning signal corresponding to KeyData. The eight KeyData scanning signals are also valid alternatively.

**Figure 11-26** Output timing of the LED module



### 11.5.3.2 Initialization

The LED module mainly provides two independent functions: keypad scanning and LED display control.

Before implementing keypad scanning, initialize the LED module as follows:

- Step 1** Configure clock dividers by writing the required clock dividers to the registers [LEDSYSTIM](#), [LEDCLKTIM](#), [LEDFRETIM](#), and [LEDKEYTIM](#).
- Step 2** Set the level when the LedCSx signal is selected, keypad scanning type, and the type of chip connected to the LED module by configuring [LEDCONFIG](#).
- Step 3** Enable keypad scanning by setting [LEDCONTROL](#) bit[3] to 1, select the interrupt mask mode by setting [LEDCONTROL](#) bit[1:0], and start the LED module by setting [LEDCONTROL](#) bit[9] to 1.



**Step 4** Obtain keypad inputs by reading [LEDKEYDATA](#), and read the keypad interrupt information by reading [LEDKEYINT](#).

----End

Before controlling the LED display, initialize the LED module as follows:

**Step 1** Configure the data to be displayed by writing the data to the registers [LEDDATA1](#), [LEDDATA2](#), [LEDDATA3](#), and [LEDDATA4](#).

**Step 2** Configure clock dividers by writing the required clock dividers to the registers [LEDSYSTEM](#), [LEDCLKTIM](#), [LEDFRETIM](#), and [LEDFLASHTIM](#).

**Step 3** Set the LED type, level of the LedCSx signal when the LED is on, and the type of the chip connected to the LED module by configuring [LEDCONFIG](#).

**Step 4** Control the blinking enable bit corresponding to each LED by configuring [LEDCONTROL](#) bit[7:4], enable LED display by setting [LEDCONTROL](#) bit[8] to 1, and start the LED module by setting [LEDCONTROL](#) bit[9] to 1.

----End

## 11.5.4 Interface Signals

[Table 11-9](#) describes the LED interface signals.

**Table 11-9** LED interface signals (8 x 1 matrix keypad scanning)

| Signal   | Width | Direction | Function Description              |
|----------|-------|-----------|-----------------------------------|
| led_key0 | 1     | I         | Keypad input 0                    |
| led_clk  | 1     | O         | LED serial output data sync clock |
| led_data | 1     | O         | LED serial output data            |

## 11.5.5 Register Summary

[Table 11-10](#) describes LED registers.

**Table 11-10** Summary of LED registers (base address: 0xF800\_3000)

| Offset Address | Register   | Description                         | Page                  |
|----------------|------------|-------------------------------------|-----------------------|
| 0x00           | LEDCONTROL | LED control register                | <a href="#">11-67</a> |
| 0x04           | LEDCONFIG  | LED display configuration register  | <a href="#">11-69</a> |
| 0x08           | LEDKEYINT  | Keypad sampling interrupt register  | <a href="#">11-70</a> |
| 0x0C           | LEDKEYDATA | LED sampling keypad status register | <a href="#">11-71</a> |



| Offset Address | Register    | Description                                          | Page                  |
|----------------|-------------|------------------------------------------------------|-----------------------|
| 0x10           | LEDCLKTIM   | LedClk signal high/low level time parameter register | <a href="#">11-72</a> |
| 0x14           | LEDFRETIM   | LED refresh frequency register                       | <a href="#">11-72</a> |
| 0x18           | LEDFLASHTIM | LED blinking frequency register                      | <a href="#">11-73</a> |
| 0x1C           | LEDKEYTIM   | Keypad scanning frequency register                   | <a href="#">11-73</a> |
| 0x20           | LEDDATA1    | First LED display data register                      | <a href="#">11-74</a> |
| 0x24           | LEDDATA2    | Second LED display data register                     | <a href="#">11-74</a> |
| 0x28           | LEDDATA3    | Third LED display data register                      | <a href="#">11-75</a> |
| 0x2C           | LEDDATA4    | Fourth LED display data register                     | <a href="#">11-75</a> |
| 0x34           | LEDSYSTIM   | LED system time frequency divider register           | <a href="#">11-75</a> |

## 11.5.6 Register Description

### LEDCONTROL

LEDCONTROL is a 10-bit read/write register. It is used to control LED display, blinking enable, keypad scanning enable, and keypad interrupts.



#### CAUTION

When the LED module works in CT1642 mode, you must disable the LED display by setting LEDCONTROL[led\_dis\_en] to 0 before disabling the LED module by setting LEDCONTROL[led\_en] to 0. Otherwise, there may be residual characters on the LED.



| Offset Address |          |                |    |                                                                 |    |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
|----------------|----------|----------------|----|-----------------------------------------------------------------|----|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|--------|------------|-----------|-----------|-----------|-----------|--------|----------|----------------|------------------|---|---|---|---|---|---|
| 0x00           |          |                |    | LEDCONTROL                                                      |    |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28                                                              | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15     | 14         | 13        | 12        | 11        | 10        | 9      | 8        | 7              | 6                | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |                                                                 |    |    |    |               |    |    |    |             |    |    |    |                   | led_en | led_dis_en | flash_en4 | flash_en3 | flash_en2 | flash_en1 | key_en | reserved | int_press_mask | int_release_mask |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0  | 0                                                               | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0      | 0          | 0         | 0         | 0         | 0         | 0      | 0        | 0              | 0                | 0 | 0 | 0 |   |   |   |
| Bits           | Access   | Name           |    | Description                                                     |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [31:10]        | -        | reserved       |    | Reserved                                                        |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [9]            | RW       | led_en         |    | LED module enable<br>0: disabled<br>1: enabled                  |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [8]            | RW       | led_dis_en     |    | LED display enable<br>0: disabled<br>1: enabled                 |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [7]            | RW       | flash_en4      |    | Blinking enable for the fourth LED<br>0: disabled<br>1: enabled |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [6]            | RW       | flash_en3      |    | Blinking enable for the third LED<br>0: disabled<br>1: enabled  |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [5]            | RW       | flash_en2      |    | Blinking enable for the second LED<br>0: disabled<br>1: enabled |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [4]            | RW       | flash_en1      |    | Blinking enable for the first LED<br>0: disabled<br>1: enabled  |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [3]            | RW       | key_en         |    | Keypad enable<br>0: disabled<br>1: enabled                      |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [2]            | -        | reserved       |    | Reserved                                                        |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |
| [1]            | RW       | int_press_mask |    | Key press interrupt mask<br>0: masked<br>1: not masked          |    |    |    |               |    |    |    |             |    |    |    |                   |        |            |           |           |           |           |        |          |                |                  |   |   |   |   |   |   |



|     |    |                  |                                                          |
|-----|----|------------------|----------------------------------------------------------|
| [0] | RW | int_release_mask | Key release interrupt mask<br>0: masked<br>1: not masked |
|-----|----|------------------|----------------------------------------------------------|

## LEDCONFIG

LEDCONFIG is a 7-bit read/write register. It is used to set the type of the chip connected to the LED module, CS level when the LED is on, LED type, keypad scanning mode, and level of the keypad scanning CS.

|        | Offset Address                                                                                      | Register Name  | Total Reset Value                                                                                                                              |  |  |  |  |                |           |           |         |               |           |        |
|--------|-----------------------------------------------------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|----------------|-----------|-----------|---------|---------------|-----------|--------|
| Bit    | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | LEDCONFIG      | 0x0000_0000                                                                                                                                    |  |  |  |  |                |           |           |         |               |           |        |
| Name   | reserved                                                                                            |                |                                                                                                                                                |  |  |  |  | leddata_dly_en | ledc_type | key8x1_cs | led_num | key_scan_mode | led_ty_cs | led_cs |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                |                                                                                                                                                |  |  |  |  |                |           |           |         |               |           |        |
| Bits   | Access                                                                                              | Name           | Description                                                                                                                                    |  |  |  |  |                |           |           |         |               |           |        |
| [31:7] | -                                                                                                   | reserved       | Reserved                                                                                                                                       |  |  |  |  |                |           |           |         |               |           |        |
| [6]    | RW                                                                                                  | leddata_dly_en | CT1642 output data delay enable<br>0: disabled<br>1: enabled                                                                                   |  |  |  |  |                |           |           |         |               |           |        |
| [5]    | RW                                                                                                  | ledc_type      | Type of the chip connected to the LED module. This bit must be set to 1 because only the CT1642 chip is supported.<br>0: reserved<br>1: CT1642 |  |  |  |  |                |           |           |         |               |           |        |
| [4]    | RW                                                                                                  | key8x1_cs      | Level of the 8 x 1 matrix keypad scanning CS<br>0: low level<br>1: high level                                                                  |  |  |  |  |                |           |           |         |               |           |        |
| [3]    | RW                                                                                                  | led_num        | Number of LED CSs. The CT1642 chip supports only four LED CSs.<br>0: four LED CSs<br>1: reserved                                               |  |  |  |  |                |           |           |         |               |           |        |



|     |    |               |                                                                                                                       |
|-----|----|---------------|-----------------------------------------------------------------------------------------------------------------------|
| [2] | RW | key_scan_mode | Keypad scanning mode. The CT1642 chip supports only the 8 x 1 scanning mode.<br>0: reserved<br>1: 8 x 1 scanning mode |
| [1] | RW | led_ty_cs     | LED type<br>0: common-cathode LED<br>1: common-anode LED                                                              |
| [0] | RW | led_cs        | LedCSx level when the LED is on. The level must be selected based on the board.<br>0: low level<br>1: high level      |

## LEDKEYINT

LEDKEYINT is a 2-bit read/write register. It is a keypad sampling interrupt status register.

|        | Offset Address |             |    |                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |           |   |             |   |   |   |  |  |  |
|--------|----------------|-------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|-----------|---|-------------|---|---|---|--|--|--|
|        | 0x08           |             |    |                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    | LEDKEYINT     |    |    |    |    |    |   |   | 0x0000_0000       |   |   |           |   |             |   |   |   |  |  |  |
| Bit    | 31             | 30          | 29 | 28                                                                                                                                                                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4         | 3 | 2           | 1 | 0 |   |  |  |  |
| Name   | reserved       |             |    |                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   | int_press |   | int_release |   |   |   |  |  |  |
| Reset  | 0              | 0           | 0  | 0                                                                                                                                                                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0         | 0 | 0           | 0 | 0 | 0 |  |  |  |
| Bits   | Access         | Name        |    | Description                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |           |   |             |   |   |   |  |  |  |
| [31:2] | -              | reserved    |    | Reserved                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |           |   |             |   |   |   |  |  |  |
| [1]    | RW             | int_press   |    | Key press interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.<br>Note: When a key release interrupt is generated, writing 1 to this bit clears the interrupt.   |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |           |   |             |   |   |   |  |  |  |
| [0]    | RW             | int_release |    | Key release interrupt flag<br>0: No interrupt is generated.<br>1: An interrupt is generated.<br>Note: When a key release interrupt is generated, writing 1 to this bit clears the interrupt. |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |           |   |             |   |   |   |  |  |  |



## LEDKEYDATA

LEDKEYDATA is an 8-bit read-only register. It is used to store the LED keypad sampling status.

In 8 x 1 scanning mode:

- For key 0, LedKey0 and CT1642 data signal 0 are valid.
- For key 1, LedKey0 and CT1642 data signal 1 are valid.
- For key 2, LedKey0 and CT1642 data signal 2 are valid.
- For key 3, LedKey0 and CT1642 data signal 3 are valid.
- For key 4, LedKey0 and CT1642 data signal 4 are valid.
- For key 5, LedKey0 and CT1642 data signal 5 are valid.
- For key 6, LedKey0 and CT1642 data signal 6 are valid.
- For key 7, LedKey0 and CT1642 data signal 7 are valid.

|        | Offset Address 0x0C |             |    |                                              |    |    |    |    |    |    |    |    |    |    |    |    | Register Name LEDKEYDATA |    |    |    |    |    |   |   | Total Reset Value 0x0000_0000 |             |             |             |             |             |             |             |
|--------|---------------------|-------------|----|----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|---|---|-------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| Bit    | 31                  | 30          | 29 | 28                                           | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                             | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
| Name   | reserved            |             |    |                                              |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   | status_key7                   | status_key6 | status_key5 | status_key4 | status_key3 | status_key2 | status_key1 | status_key0 |
| Reset  | 0                   | 0           | 0  | 0                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                             | 0           | 0           | 0           | 0           | 0           |             |             |
| Bits   | Access              | Name        |    | Description                                  |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [31:8] | -                   | reserved    |    | Reserved                                     |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [7]    | RO                  | status_key7 |    | Status of key 7<br>0: released<br>1: pressed |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [6]    | RO                  | status_key6 |    | Status of key 6<br>0: released<br>1: pressed |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [5]    | RO                  | status_key5 |    | Status of key 5<br>0: released<br>1: pressed |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [4]    | RO                  | status_key4 |    | Status of key 4<br>0: released<br>1: pressed |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |
| [3]    | RO                  | status_key3 |    | Status of key 3<br>0: released<br>1: pressed |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                               |             |             |             |             |             |             |             |



|     |    |             |                                              |
|-----|----|-------------|----------------------------------------------|
| [2] | RO | status_key2 | Status of key 2<br>0: released<br>1: pressed |
| [1] | RO | status_key1 | Status of key 1<br>0: released<br>1: pressed |
| [0] | RO | status_key0 | Status of key 0<br>0: released<br>1: pressed |

## LEDCLKTIM

**LEDCLKTIM** is a 4-bit read/write register. It is used to define the frequency of the LED serial sync clock LedClk.

Assume that the system clock is 24 MHz, the value of LEDClkTim is N, the frequency of the LED serial clock LedClk is F, and the LEDSysTim system time frequency divider is Q:

$$F = 24 / [(N + 1) \times 2 \times (Q + 1)] \text{ (unit: MHz)}$$

| Offset Address |          |             |    |           |                                          |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
|----------------|----------|-------------|----|-----------|------------------------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|----|----|----|----|----|----|---|---|-------------|---|---|---|---|---|---|---|
| 0x10           |          |             |    | LEDCLKTIM |                                          |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| Bit            | 31       | 30          | 29 | 28        | 27                                       | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |             |    |           |                                          |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   | led_clk_tim |   |   |   |   |   |   |   |
| Reset          | 0        | 0           | 0  | 0         | 0                                        | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name        |    |           | Description                              |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| [31:4]         | -        | reserved    |    |           | Reserved                                 |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| [3:0]          | RW       | led_clk_tim |    |           | Frequency of the LED serial clock LedClk |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |

LEDFRETIM

**LEDFRETIM** is a 4-bit read/write register. It is used to define the LED refresh frequency and the keypad scanning frequency in 4 x 2 or 8 x 1 scanning mode.

Assume that the system clock frequency is 24 MHz, the value of LEDClkTim is N, the value of LEDFreTim is M, the LED refresh frequency is F, the value of LEDSysTim is Q, and the number of LEDs is O.

The refresh frequency of the CT1642 LED is calculated as follows:

$$F = 24 / [(N + 1) \times (O + 1) \times 16 \times 40 \times (M + 1) \times (P + 1)] \text{ (unit: MHz)}$$



## LEDFLASHTIM

**LEDFLASHTIM** is an 8-bit read/write register. It is used to define the LED blinking frequency.

Assume that the system clock frequency is 24 MHz, the value of LEDClkTim is N, the value of LEDFreTim is M, the value of LEDFlashTim is L, the LED blinking frequency is F, the value of LEDSysTim is Q, and the number of LEDs is O.

The refresh frequency of the CT1642 LED is calculated as follows:

$$F = 24 / [(N + 1) \times (Q + 1) \times 16 \times 40 \times (M + 1) \times (O + 1)] \text{ (unit: MHz)}$$

| Offset Address |          |               |    |    |                     |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|---------------|----|----|---------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x18           |          |               |    |    |                     |    |    | LEDFLASHTIM   |    |    |    |    |    |    |    | 0x0000_0000       |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30            | 29 | 28 | 27                  | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |               |    |    |                     |    |    |               |    |    |    |    |    |    |    |                   | led_flash_tim |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0             | 0  | 0  | 0                   | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name          |    |    | Description         |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:8]         | -        | reserved      |    |    | Reserved            |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [7:0]          | RW       | led_flash_tim |    |    | LED blink frequency |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEDKEYTIM

**LEDKEYTIM** is a 4-bit read/write register. It is used to define the keypad scanning frequency.

Assume that the system clock frequency is 24 MHz, the value of LEDClkTim is N, the value of LEDFreTim is M, the value of LEDKeyTim is P, the keypad scanning frequency is F, the value of LEDSysTim is Q, and the number of LEDs is O.

The scanning frequency of the CT1642 keypad is calculated as follows:

$$F = 24 / [(N + 1) \times (Q + 1) \times 16 \times 40 \times (M + 1) \times (O + 1) \times 8 \times (P + 1)] \text{ (unit: MHz)}$$



| Offset Address |          |             |    |           |                           |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
|----------------|----------|-------------|----|-----------|---------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|----|----|----|----|----|----|---|---|-------------|---|---|---|---|---|---|---|
| 0x1C           |          |             |    | LEDKEYTIM |                           |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| Bit            | 31       | 30          | 29 | 28        | 27                        | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |             |    |           |                           |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   | led_key_tim |   |   |   |   |   |   |   |
| Reset          | 0        | 0           | 0  | 0         | 0                         | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name        |    |           | Description               |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| [31:4]         | -        | reserved    |    |           | Reserved                  |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |
| [3:0]          | RW       | led_key_tim |    |           | Keypad scanning frequency |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |             |   |   |   |   |   |   |   |

## LEDDATA1

**LEDDATA1** is an 8-bit read/write register. It is used to configure the data displayed on the first LED.

| Offset Address |          |           |                                 |          |    |             |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|---------------------------------|----------|----|-------------|----|---------------|----|----|----|-------------|----|----|----|-------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x20           |          |           |                                 | LEDDATA1 |    |             |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29                              | 28       | 27 | 26          | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |                                 |          |    |             |    |               |    |    |    |             |    |    |    |                   | led_data1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0                               | 0        | 0  | 0           | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
|                | Bits     | Access    | Name                            |          |    | Description |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:8]         | -        | reserved  | Reserved                        |          |    |             |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [7:0]          | RW       | led_data1 | Data displayed on the first LED |          |    |             |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEDDATA2

**LEDDATA2** is an 8-bit read/write register. It is used to configure the data displayed on the second LED.

| Offset Address |          |           |    |          |                                  |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|----------|----------------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x24           |          |           |    | LEDDATA2 |                                  |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28       | 27                               | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |    |          |                                  |    |    |               |    |    |    |             |    |    |    |                   | led_data2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0        | 0                                | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name      |    |          | Description                      |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:8]         | -        | reserved  |    |          | Reserved                         |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [7:0]          | RW       | led_data2 |    |          | Data displayed on the second LED |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



### LEDDATA3

LEDDATA3 is an 8-bit read/write register. It is used to configure the data displayed on the third LED.

| Offset Address |          |           |    |    |                                 |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|----|---------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x28           |          |           |    |    |                                 |    |    | LEDDATA3      |    |    |    |    |    |    |    | 0x0000_0000       |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28 | 27                              | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |    |    |                                 |    |    |               |    |    |    |    |    |    |    |                   | led_data3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0  | 0                               | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name      |    |    | Description                     |    |    |               |    |    |    |    |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:8]         | -        | reserved  |    |    | Reserved                        |    |    |               |    |    |    |    |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [7:0]          | RW       | led_data3 |    |    | Data displayed on the third LED |    |    |               |    |    |    |    |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEDDATA4

LEDDATA4 is an 8-bit read/write register. It is used to configure the data displayed on the fourth LED.

| Offset Address |          |           |    |          |                                  |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|----------|----------------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x2C           |          |           |    | LEDDATA4 |                                  |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28       | 27                               | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |           |    |          |                                  |    |    |               |    |    |    |             |    |    |    |                   | led_data4 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0        | 0                                | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name      |    |          | Description                      |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:8]         | -        | reserved  |    |          | Reserved                         |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [7:0]          | RW       | led_data4 |    |          | Data displayed on the fourth LED |    |    |               |    |    |    |             |    |    |    |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

LEDSYSTIM

**LEDSYSTIM** is an LED system time frequency divider register. It is used to configure the global frequency divider for the LED clock.



| Offset Address |          |             |                                   |    |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |    |   | Total Reset Value |             |   |   |   |   |   |   |   |
|----------------|----------|-------------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|---|-------------------|-------------|---|---|---|---|---|---|---|
| 0x34           |          |             |                                   |    |    |    |    |    |    |    |    |    |    |    |    | LEDSYSTIM     |    |    |    |    |    |    |   | 0x0000_0000       |             |   |   |   |   |   |   |   |
| Bit            | 31       | 30          | 29                                | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |             |                                   |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   | led_sys_tim |   |   |   |   |   |   |   |
| Reset          | 0        | 0           | 0                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0           | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name        | Description                       |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |
| [31:4]         | -        | reserved    | Reserved                          |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |
| [3:0]          | RW       | led_sys_tim | LED system time frequency divider |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |   |                   |             |   |   |   |   |   |   |   |

## 11.6 SPI

### 11.6.1 Overview

The SPI controller implements serial-to-parallel conversion and parallel-to-serial conversion, and can serve as a master to communicate with peripherals in sync serial mode. The SPI controller supports three peripheral interfaces including the SPI, TI serial sync interface, and microwire interface.

### 11.6.2 Features

The Hi3796M V100 SPI is a master interface and its working reference clock is 100 MHz. The SPI can output SPI\_CLK with the maximum frequency of 50 MHz.

The SPI has the following features:

- Programmable interface clock frequency
- Two separate FIFOs, one acting as an RX FIFO and the other as a TX FIFO. Each FIFO is 16-bit wide and 256-location deep.
- 4-bit to 16-bit serial data frame
- Internal loopback test mode
- Three types of peripheral interfaces including the SPI, microwire interface, and TI sync serial interface
- Configurable full-duplex mode, clock polarity, and phase for the SPI
- Half-duplex mode for the microwire interface
- Full-duplex mode for the TI serial sync interface

### 11.6.3 Function Description

#### Typical Applications

Figure 11-27 shows the block diagram of the SPI connected to a single slave. The default CS pin SPI\_CS0 is used.

**Figure 11-27** SPI connected to a single slave

For details about how to select SPI CSs, see section 3.5 "Peripheral Controllers".

## 11.6.4 Peripheral Bus Timings

The abbreviations and acronyms in [Figure 11-28](#) to [Figure 11-35](#) are described as follows:

- MSB: most significant bit
- LSB: least significant bit
- Q: undefined signal

### SPI Pins



SPO indicates the SPICLKOUT polarity, and SPH indicates the SPICLKOUT phase. The corresponding register bits are [SPICR0](#) bit[7:6].

#### (1) SPO = 0 and SPH = 0

[Figure 11-28](#) shows the format of a single SPI frame.

**Figure 11-28** Format of a single SPI frame (SPO = 0, SPH = 0)

[Figure 11-29](#) shows the format of consecutive SPI frames.



**Figure 11-29** Format of consecutive SPI frames (SPO = 0, SPH = 0)



When the SPI is idle in this mode:

- The SPI\_CLK signal is set to low.
- The SPI\_CS\_N signal is set to high.
- The TX data line SPI\_DO is forced to low.

When the SPI is enabled and there is valid data in the TX FIFO, setting the SPI\_CS\_N signal to low starts a data transfer. The data from the slave device is immediately transmitted to the data RX line SPI\_DI of the master device. Half an SPI\_CLK cycle later, the valid master data is transmitted to SPI\_DO. At this time, both the master data and slave data are valid. The SPI\_CLK pin changes to high level half an SPI\_CLK cycle later. Then, data is captured at the rising edge of the SPI\_CLK clock and transmitted at the falling edge.

If a single word is transferred, SPI\_CS\_N is restored to high level one SPI\_CLK cycle later after the last bit is captured.

For continuous transfer, the SPI\_CS\_N signal must be pulled up by one SPI\_CLK cycle at each word transfer interval. This is because when SPH is 0, the slave select pin retains the data in the internal serial device register. Therefore, the master must pull the SPI\_CS\_N signal up at each word transfer interval in consecutive transfer. When the consecutive transfer ends, SPI\_CS\_N is restored to high one SPI\_CLK cycle later after the last 1-bit data is captured.

## (2) SPO = 0 and SPH = 1

Figure 11-30 shows the format of a single SPI frame.

**Figure 11-30** Format of a single SPI frame (SPO = 0, SPH = 1)



Figure 11-31 shows the format of consecutive SPI frames.



**Figure 11-31** Format of consecutive SPI frames (SPO = 0, SPH = 1)



When the SPI is idle in this mode:

- The SPI\_CLK signal is set to low.
- The SPI\_CS\_N signal is set to high.
- The TX data line SPI\_DO is forced to low.

When the SPI is enabled and there is valid data in the TX FIFO, setting the SPI\_CS\_N signal to low starts a data transfer. If data transfer starts, the master data and slave data are valid on their respective transmission lines half an SPI\_CLK cycle later. SPI\_CLK becomes valid at the first rising edge. Data is captured at the falling edge of SPI\_CLK and transmitted at the rising edge.

If a single word is transferred, SPI\_CS\_N is restored to high level one SPI\_CLK cycle later after the data of the last bit is captured.

If consecutive words are transferred, SPI\_CS\_N retains low at the word transfer interval. When the consecutive transfer ends, SPI\_CS\_N is restored to high level one SPI\_CLK cycle later after the last 1-bit data is captured.

### (3) SPO = 1 and SPH = 0

Figure 11-32 shows the format of a single SPI frame.

**Figure 11-32** Format of a single SPI frame (SPO = 1, SPH = 0)



Figure 11-33 shows the format of consecutive SPI frames.



**Figure 11-33** Format of consecutive SPI frames (SPO = 1, SPH = 0)



When the SPI is idle in this mode:

- The SPI\_CLK signal is set to high.
- The SPI\_CS\_N signal is set to high.
- The TX data line SPI\_DO is forced to low.

When the SPI is enabled and there is valid data in the TX FIFO, setting the SPI\_CS\_N signal to low starts a data transfer. The slave data is immediately transmitted to the master RX data line SPI\_DI. Half an SPI\_CLK cycle later, the valid master data is transmitted to SPI\_DO. Another half SPI\_CLK cycle later, the SPI\_CLK master pin is set to low, indicating that data is captured at the falling edge of the SPI\_CLK clock and transmitted at the rising edge.

If a single word is transferred, SPI\_CS\_N is restored to high level one SPI\_CLK cycle later after the data of the last bit is captured.

If consecutive words are transferred, the SPI\_CS\_N signal must be pulled up at each word transfer interval. The reason is that when SPH is 0, the slave select pin fixes the data in the internal serial device register to maintain the data unchanged. SPI\_CS\_N is restored to high one SPI\_CLK clock cycle later after the last bit is captured.

#### (4) SPH = 1 and SPO = 1

Figure 11-34 shows the format of a single SPI frame.

**Figure 11-34** SPI single frame format (SPO = 1, SPH = 1)



Figure 11-35 shows the format of consecutive SPI frames.



**Figure 11-35** SPI consecutive frame format (SPO = 1, SPH = 1)



When the SPI is idle in this mode:

- The SPI\_CLK signal is set to high.
- The SPI\_CS\_N signal is set to high.
- The TX data line SPI\_DO is forced to low.

When the SPI is enabled and valid data is ready in the TX FIFO, setting the SPI\_CS\_N master signal to low starts the data transfer. Half an SPI\_CLK cycle later, the master data and slave data are valid on their respective transmission lines. SPI\_CLK becomes valid from a falling edge. Data is captured at the rising edge of the SPI\_CLK clock and transmitted at the falling edge.

If a single word is transferred, SPI\_CS\_N is restored to high one SPI\_CLK cycle later after the last bit is captured.

If consecutive words are transferred, the SPI\_CS\_N signal retains low. SPI\_CS\_N is restored to high one SPI\_CLK cycle later after the last 1-bit data is captured. For consecutive transfer, SPI\_CS\_N retains low during data transfer, and the end mode is the same as that during single word transfer.

## TI Serial Synchronous Interface

Figure 11-36 shows the format of a single frame for the TI synchronous serial interface.

**Figure 11-36** Format of a single frame for the TI synchronous serial interface



Figure 11-37 shows the format of consecutive frames for the TI synchronous serial interface.

**Figure 11-37** Format of consecutive frames for the TI synchronous serial interface

When the SPI is idle in this mode:

- The SPICK signal is set to low.
- The SPICSN signal is set to low.
- The TX data line SPIIDO retains high impedance.

If there is data in the TX FIFO, SPI\_CS\_N generates a high level pulse in one SPI\_CK clock cycle. Then the data to be transmitted is transferred from the TX FIFO to the TX logic serial shift register. The MSBs of 4-bit to 16-bit data frames are shifted and output from SPI\_DO at the next rising edge of the SPI\_CK clock. Similarly, the MSBs of data received from the external serial slave device are shifted and input from the SPI\_DI pin.

The SPI and off-chip serial device stores the data in the serial shift register at the falling edge of the SPI\_CK clock. The RX serial register transmits the data to the RX FIFO at the rising edge of the first SPI\_CK clock after receiving the LSB.

## National Semiconductor Microwire Interface

[Figure 11-38](#) shows the format of a single frame for the national semiconductor microwire interface.

**Figure 11-38** Format of a single frame for the national semiconductor microwire interface

0 to 255 clock cycles can be delayed between the end of the SPI\_DO LSB and the start of the SPI\_DI MSB.

[Figure 11-39](#) shows the format of consecutive frames for the national semiconductor microwire interface.

**Figure 11-39** Format of consecutive frames for the national semiconductor microwire interface

0 to 255 clock cycles can be delayed between the end of the SPI\_DO LSB and the start of the SPI\_DI MSB.

The formats of the frames for the microwire interface and SPI are similar. Both of them use the master-slave transfer technology. The only difference is that the SPI works in full-duplex mode while the microwire interface works in half-duplex mode. Before serial data is transmitted to an external chip over the SPI, 8-bit control words are added. The SPI does not receive any data during this process. After the transfer is complete, the external chip decodes the received data. One clock cycle later after the 8-bit control information, the slave starts to acknowledge the required data. The returned data length is 4 bits to 16 bits, and therefore the length of an entire frame is 13 bits to 25 bits.

When the SPI is idle in this mode:

- The SPI\_CLK signal is set to low.
- The SPI\_CS\_N signal is set to high.
- The TX data signal SPI\_DO is forced to low level.

Writing one control byte to the TX FIFO starts a data transfer. The data transfer is triggered at the falling edge of SPI\_CS\_N. Data in the TX FIFO is transmitted to the serial shift register. The MSB of the 8-bit control frame is transmitted to the TX pin SPI\_DO. During frame transfer, SPI\_CS\_N retains low, and SPI\_DI retains high impedance.

The off-chip serial slave latches the data in the serial shift register at each rising edge of the SPI\_CLK clock. When the slave latches the last 1-bit data, it starts to decode the received data after waiting one clock cycle, and then provides the required data to the SPI. Each bit is written to SPI\_DI at the falling edge of the SPI\_CLK clock. For a single data transfer, SPI\_CS\_N is pulled up at the end of the frame one clock cycle later after the last 1-bit data is written to the RX serial register, ensuring that the received data is transmitted to the RX FIFO.

The start and end of consecutive data transfer are the same as those of the single data transfer. During consecutive data transfer, the SPI\_CS\_N signal retains low, and the transferred data is consecutive. The control word of the next frame is adjacent to the LSB of the previous frame. When the LSB of the frame is latched to the SPI, each received value is fetched from the RX shift register at the falling edge of the SPI\_CLK clock.

## Interface Timings

Figure 11-40 SPI timing



Table 11-11 SPI timing parameters

| Parameter | Description                     | Min  | Max | Unit |
|-----------|---------------------------------|------|-----|------|
| Tdd       | Output data delay               | -3.5 | 5   | ns   |
| Tds       | Input control signal setup time | 23   | -   | ns   |
| Tdh       | Input control signal hold time  | 0    | -   | ns   |

## 11.6.5 Operating Mode

The SPI supports data transfer in interrupt mode or query mode.

### Clock and Reset

The frequency of the output SPI clock is calculated as follows:

$$F_{\text{SSPCLKOUT}} = F_{\text{SSPCLK}} / (\text{CPSDVR} \times (1 + \text{SCR}))$$

$F_{\text{SSPCLK}}$  indicates the frequency of the SPI working reference clock, which is 100 MHz.

For details about CPSDVR and SCR, see the related registers.

The SPI working reference clock supports clock gating. The clock gating of SSP0 is controlled by configuring PERI\_CRG28 bit[0]. Writing 0 to the corresponding bit disables the clock, and writing 1 to the corresponding bit enables the clock. The default value is 1 during power-on.

The SPI supports separate soft reset, which is controlled by configuring PERI\_CRG28 bit[1]. Writing 0 to PERI\_CRG28 bit[1] deasserts the soft reset on the SPI, and writing 1 to PERI\_CRG28 bit[1] soft-resets the SPI. The default value is 0 during power-on.



## Handling Interrupts

The SPI has the following five interrupts. The first four interrupts have independent interrupt sources and are maskable and active high.

- **SPIRXINTR**  
RX FIFO interrupt. When there are four or more valid data segments in the RX FIFO, the interrupt is enabled.
- **SPITXINTR**  
TX FIFO interrupt. When there are four or less valid data segments in the TX FIFO, the interrupt is enabled.
- **SPIRORINTR**  
RX overflow interrupt. When the FIFO is full and new data needs to be written to the FIFO, FIFO overflow occurs and the interrupt is enabled. In this case, data is written to the RX shift register but not the FIFO.
- **SPIRTINTR**  
RX timeout interrupt. When the RX FIFO is not empty and the SPI is idle for more than a fixed 32-bit cycle, the interrupt is enabled.  
In this case, data in the RX FIFO needs to be transmitted. When the RX FIFO is read empty or new data is received in the SPIRXD, the interrupt is disabled. The interrupt can be cleared by writing to SPIICR[RTIC].
- **SPIINTR**  
Combined interrupt, which is obtained after the preceding four interrupts are ORed. If any of the preceding four interrupts is enabled, this interrupt is enabled.

For details about SPIINTR, see section 3.6 "Interrupt System."

## Initializing the SPI

The SPI is initialized as follows:

- Step 1** Write 0 to **SPICR1[sse]** to disable the SPI.
- Step 2** Write to **SPICR0** to set the parameters such as the frame format and transfer data bit width.
- Step 3** Configure **SPICPSR** to specify the required clock divider.
- Step 4** In interrupt mode, configure **SPIIMSC** to enable the corresponding interrupts; in query mode, disable the generation of interrupts.
- Step 5** In interrupt mode, configure **SPITXFIFOCCR** and **SPIRXFIFOCCR**.

----End

## Transmitting Data in Query Mode

The depth of the TX or RX FIFO is 512 bytes.

Data is transmitted in query mode as follows:

- Step 1** If two CSs are used, select the CS to be operated by configuring PERI\_CTRL bit[4].
- Step 2** Write 1 to **SPICR1[sse]** to enable the SPI.
- Step 3** Write the data to be transmitted to SPIDR continuously.



- Step 4** Poll **SPISR** until **SPISR[bsy]** is 0, indicating that the bus is not busy. If **SPISR[tfe]** is 1, the TX FIFO is empty; if **SPISR[rne]** is 1, the RX FIFO is not empty.
- Step 5** Read all data from the RX FIFO. You can check whether the RX FIFO is empty by querying **SPISR[rne]**.



## CAUTION

As the SPI works in full-duplex mode, a data segment is received each time a data segment is transmitted. The RX FIFO must be cleared even data is only transmitted.

- Step 6** Write 0 to **SPICR1[sse]** to disable the SPI.

----End

## Transmitting Data in Interrupt Mode

Data is transmitted in interrupt mode as follows:

- Step 1** If two CSs are used, select the CS to be operated by configuring PERI\_CTRL bit[4].
- Step 2** Write 1 to **SPICR1[sse]** to enable the SPI.
- Step 3** Write the data to be transmitted to SPIDR continuously.
- Step 4** Wait for the SPIRXINTR interrupt to read data. Repeat this step until all data is read.



## CAUTION

As the SPI works in full-duplex mode, a data segment is received each time a data segment is transmitted. The RX FIFO must be cleared even data is only transmitted.

- Step 5** Write 0 to **SPICR1[sse]** to disable the SPI.

----End

## 11.6.6 Register Summary

Table 11-12 describes SPI registers.

The base address for SPI registers is 0xF8B1\_A000.

**Table 11-12** Summary of SPI registers

| Offset Address | Register | Description        | Page  |
|----------------|----------|--------------------|-------|
| 0x000          | SPICR0   | Control register 0 | 11-87 |
| 0x004          | SPICR1   | Control register 1 | 11-88 |



| Offset Address | Register     | Description                      | Page  |
|----------------|--------------|----------------------------------|-------|
| 0x008          | SPIDR        | Data register                    | 11-89 |
| 0x00C          | SPISR        | Status register                  | 11-90 |
| 0x010          | SPICPSR      | Clock divider register           | 11-90 |
| 0x014          | SPIIMSC      | Interrupt mask register          | 11-91 |
| 0x018          | SPIRIS       | Raw interrupt status register    | 11-91 |
| 0x01C          | SPIMIS       | Masked interrupt status register | 11-92 |
| 0x020          | SPIICR       | Interrupt clear register         | 11-92 |
| 0x028          | SPITXFIFOOCR | TX FIFO control register         | 11-93 |
| 0x02C          | SPIRXFIFOOCR | RX FIFO control register         | 11-94 |

## 11.6.7 Register Description

### SPICR0

SPICR0 is SPI control register 0.

| Offset Address |        | Register Name |       |                                                                                                                                                                                                                                                                                             |     |     |     |     |        |     |     | Total Reset Value |     |  |
|----------------|--------|---------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|-----|--------|-----|-----|-------------------|-----|--|
| Bit            | 15 14  | 13 12         | 11 10 | 9 8                                                                                                                                                                                                                                                                                         | 7 6 | 5 4 | 3 2 | 1 0 | 0x0000 |     |     |                   |     |  |
| Name           | scr    |               |       |                                                                                                                                                                                                                                                                                             |     |     |     |     | sph    | spo | frf | dss               |     |  |
| Reset          | 0 0    | 0 0           | 0 0   | 0 0                                                                                                                                                                                                                                                                                         | 0 0 | 0 0 | 0 0 | 0 0 | 0 0    | 0 0 | 0 0 | 0 0               | 0 0 |  |
| Bits           | Access | Name          |       | Description                                                                                                                                                                                                                                                                                 |     |     |     |     |        |     |     |                   |     |  |
| [15:8]         | RW     | scr           |       | Serial clock rate, ranging from 0 to 255<br>The field value is used to calculate the SPI TX and RX bit rates.<br>The formula is as follows: Bit rate = $F_{SPICLK}/[CPSDVSR \times (1 + SCR)]$<br>CPSDVSR is an even number ranging from 2 to 254, and is specified by configuring SPICPSR. |     |     |     |     |        |     |     |                   |     |  |
| [7]            | RW     | sph           |       | SPICLKOUT phase. For details, see section 11.6.4 "Peripheral Bus Timings."                                                                                                                                                                                                                  |     |     |     |     |        |     |     |                   |     |  |
| [6]            | RW     | spo           |       | SPICLKOUT polarity. For details, see section 11.6.4 "Peripheral Bus Timings."                                                                                                                                                                                                               |     |     |     |     |        |     |     |                   |     |  |



|       |    |     |                                                                                                                                                                                                                                                                 |
|-------|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:4] | RW | frf | Frame format<br>00: Motorola SPI frame<br>01: TI synchronous serial frame<br>10: national microwire frame<br>11: reserved                                                                                                                                       |
| [3:0] | RW | dss | Data bit width<br>0011: 4 bits<br>1000: 9 bits<br>1101: 14 bits<br>0100: 5 bits<br>1001: 10 bits<br>1110: 15 bits<br>0101: 6 bits<br>1010: 11 bits<br>1111: 16 bits<br>0110: 7 bits<br>1011: 12 bits<br>0111: 8 bits<br>1100: 13 bits<br>Other values: reserved |

## SPICR1

SPICR1 is SPI control register 1.

| Offset Address<br>0x004 |        |         |    |                                                                                                                             |    |    |   |   |   |   |   | Register Name<br>SPICR1 |   |          |        | Total Reset Value<br>0x7F00 |    |     |     |
|-------------------------|--------|---------|----|-----------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|---|-------------------------|---|----------|--------|-----------------------------|----|-----|-----|
| Bit                     | 15     | 14      | 13 | 12                                                                                                                          | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4                       | 3 | 2        | 1      | 0                           |    |     |     |
| Name                    | waiten | waitval |    |                                                                                                                             |    |    |   |   |   |   |   |                         |   | reserved | bigend | reserved                    | ms | sse | lmb |
| Reset                   | 0      | 1       | 1  | 1                                                                                                                           | 1  | 1  | 1 | 1 | 0 | 0 | 0 | 0                       | 0 | 0        | 0      | 0                           | 0  | 0   |     |
| Bits                    | Access | Name    |    | Description                                                                                                                 |    |    |   |   |   |   |   |                         |   |          |        |                             |    |     |     |
| [15]                    | RW     | waiten  |    | Wait enable. This bit is valid when SPICR0[frf] is set to the national microwire frame format.<br>0: disabled<br>1: enabled |    |    |   |   |   |   |   |                         |   |          |        |                             |    |     |     |



|        |    |          |                                                                                                                                                                                        |
|--------|----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14:8] | RW | waitval  | Number of waiting beats between read and write operations in national microwire frame format. This field is valid when the waiten bit is 1 and the frame format is national microwire. |
| [7:5]  | RW | reserved | Reserved                                                                                                                                                                               |
| [4]    | RW | bigend   | Data endian mode<br>0: little endian<br>1: big endian                                                                                                                                  |
| [3]    | RW | reserved | Reserved                                                                                                                                                                               |
| [2]    | RW | ms       | Master or slave mode. This field can be changed only when the SPI is disabled.<br>0: master mode (default)<br>1: reserved                                                              |
| [1]    | RW | sse      | SPI enable<br>0: disabled<br>1: enabled                                                                                                                                                |
| [0]    | RW | lbtm     | Loopback mode<br>0: The normal serial port operation is enabled.<br>1: The output of the TX serial shift register internally connects to the input of the RX serial shift register.    |

## SPIDR

SPIDR is a data register.

|              | Offset Address |      |    |                                                                                                                                                                                                                                          |    |    |   |   | Register Name |   |   |   |   |   |   |   | Total Reset Value |  |  |  |  |  |  |  |
|--------------|----------------|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---------------|---|---|---|---|---|---|---|-------------------|--|--|--|--|--|--|--|
|              | 0x008          |      |    |                                                                                                                                                                                                                                          |    |    |   |   | SPIDR         |   |   |   |   |   |   |   | 0x0000            |  |  |  |  |  |  |  |
| Bit          | 15             | 14   | 13 | 12                                                                                                                                                                                                                                       | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |
| <b>Name</b>  |                |      |    |                                                                                                                                                                                                                                          |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |
| <b>Reset</b> |                |      |    |                                                                                                                                                                                                                                          |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |
| Bits         | Access         | Name |    | Description                                                                                                                                                                                                                              |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |
| [15:0]       | RW             | data |    | TX or RX FIFO<br>Read: RX FIFO<br>Write: TX FIFO<br><br>If the number of data bits is less than 16, data must be right-aligned. The TX logic ignores the unused upper bits, and the RX logic automatically aligns the data to the right. |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |



## SPISR

SPISR is a status register.

|        | Offset Address |          |    |                                                          |    |    |   |   | Register Name |   |   |   |     |     |     |     | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----------------------------------------------------------|----|----|---|---|---------------|---|---|---|-----|-----|-----|-----|-------------------|--|--|--|--|--|--|--|
|        | 0x00C          |          |    |                                                          |    |    |   |   | SPISR         |   |   |   |     |     |     |     | 0x0003            |  |  |  |  |  |  |  |
| Bit    | 15             | 14       | 13 | 12                                                       | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3   | 2   | 1   | 0   |                   |  |  |  |  |  |  |  |
| Name   | reserved       |          |    |                                                          |    |    |   |   |               |   |   |   | bsy | rff | rne | tnf | tfe               |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0                                                        | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0   | 0   | 1   | 1   |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    | Description                                              |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [15:5] | RW             | reserved |    | Reserved                                                 |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [4]    | RW             | bsy      |    | SPI busy flag<br>0: ready<br>1: busy                     |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [3]    | RW             | rff      |    | Whether the RX FIFO is full<br>0: not full<br>1: full    |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [2]    | RW             | rne      |    | Whether the RX FIFO is empty<br>0: empty<br>1: not empty |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [1]    | RW             | tnf      |    | Whether the TX FIFO is full<br>0: full<br>1: not full    |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |
| [0]    | RW             | tfe      |    | Whether the TX FIFO is empty<br>0: not empty<br>1: empty |    |    |   |   |               |   |   |   |     |     |     |     |                   |  |  |  |  |  |  |  |

## SPICPSR

SPICPSR is a clock divider register.

|        | Offset Address |          |    |             |    |    |   |   | Register Name |   |   |   |         |   |   |   | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|----------|----|-------------|----|----|---|---|---------------|---|---|---|---------|---|---|---|-------------------|--|--|--|--|--|--|--|
|        | 0x010          |          |    |             |    |    |   |   | SPICPSR       |   |   |   |         |   |   |   | 0x0000            |  |  |  |  |  |  |  |
| Bit    | 15             | 14       | 13 | 12          | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3       | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |
| Name   | reserved       |          |    |             |    |    |   |   |               |   |   |   | cpsdvsr |   |   |   |                   |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0           | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0       | 0 | 0 | 0 |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    | Description |    |    |   |   |               |   |   |   |         |   |   |   |                   |  |  |  |  |  |  |  |
| [15:8] | RW             | reserved |    | Reserved    |    |    |   |   |               |   |   |   |         |   |   |   |                   |  |  |  |  |  |  |  |



|       |    |         |                                                                                                                                                       |
|-------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | RW | cpsdvsr | Clock divider<br>The value must be an even number ranging from 2 to 254. It depends on the frequency of the input clock SPICLK. The LSB is read as 0. |
|-------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|

## SPIIMSC

SPIIMSC is an interrupt mask register. The value 0 indicates masked, and the value 1 indicates not masked.

|        | Offset Address |          | Register Name |                                                                                                                                                                                                       |    |    |   |   |   |   |      |      | Total Reset Value |       |   |   |
|--------|----------------|----------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|------|------|-------------------|-------|---|---|
|        | 0x014          |          | SPIIMSC       |                                                                                                                                                                                                       |    |    |   |   |   |   |      |      | 0x0000            |       |   |   |
| Bit    | 15             | 14       | 13            | 12                                                                                                                                                                                                    | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4    | 3                 | 2     | 1 | 0 |
| Name   | reserved       |          |               |                                                                                                                                                                                                       |    |    |   |   |   |   | txim | rxim | rtim              | rorim |   |   |
| Reset  | 0              | 0        | 0             | 0                                                                                                                                                                                                     | 0  | 0  | 0 | 0 | 0 | 0 | 0    | 0    | 0                 | 0     | 0 | 0 |
| Bits   | Access         | Name     |               | Description                                                                                                                                                                                           |    |    |   |   |   |   |      |      |                   |       |   |   |
| [15:4] | RW             | reserved |               | Reserved                                                                                                                                                                                              |    |    |   |   |   |   |      |      |                   |       |   |   |
| [3]    | RW             | txim     |               | TX FIFO interrupt mask<br>0: masked when the TX FIFO is half empty or less<br>1: not masked when the TX FIFO is half empty or less                                                                    |    |    |   |   |   |   |      |      |                   |       |   |   |
| [2]    | RW             | rxim     |               | RX FIFO interrupt mask<br>0: masked when the RX FIFO is half empty or less<br>1: not masked when the RX FIFO is half empty or less                                                                    |    |    |   |   |   |   |      |      |                   |       |   |   |
| [1]    | RW             | rtim     |               | RX timeout interrupt mask<br>0: masked<br>1: not masked                                                                                                                                               |    |    |   |   |   |   |      |      |                   |       |   |   |
| [0]    | RW             | rorim    |               | RX overflow interrupt mask<br>0: masked<br>1: not masked<br>When the value is 1, the hardware stream control function is enabled. That is, when the RX FIFO is full, the SPI stops transmitting data. |    |    |   |   |   |   |      |      |                   |       |   |   |

## SPIRIS

SPIRIS is a raw interrupt status register. The value 0 indicates that no interrupt is generated, and the value 1 indicates that an interrupt is generated.



|        | Offset Address<br>0x018 |          |    |                                       |    |    |   |   | Register Name<br>SPIRIS |   |   |   |   |   |       |       | Total Reset Value<br>0x0008 |         |  |  |
|--------|-------------------------|----------|----|---------------------------------------|----|----|---|---|-------------------------|---|---|---|---|---|-------|-------|-----------------------------|---------|--|--|
| Bit    | 15                      | 14       | 13 | 12                                    | 11 | 10 | 9 | 8 | 7                       | 6 | 5 | 4 | 3 | 2 | 1     | 0     |                             |         |  |  |
| Name   | reserved                |          |    |                                       |    |    |   |   |                         |   |   |   |   |   | txris | rxris | rtris                       | rrorris |  |  |
| Reset  | 0                       | 0        | 0  | 0                                     | 0  | 0  | 0 | 0 | 0                       | 0 | 0 | 0 | 1 | 0 | 0     | 0     |                             |         |  |  |
| Bits   | Access                  | Name     |    | Description                           |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [15:4] | RO                      | reserved |    | Reserved                              |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [3]    | RO                      | txris    |    | Raw TX FIFO interrupt status          |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [2]    | RO                      | rxris    |    | Raw RX FIFO interrupt status          |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [1]    | RO                      | rtris    |    | Raw RX timeout interrupt status       |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [0]    | RO                      | rrorris  |    | Raw RX FIFO overflow interrupt status |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |

## SPIMIS

SPIMIS is a masked interrupt status register. The value 0 indicates that no interrupt is generated, and the value 1 indicates that an interrupt is generated.

|        | Offset Address<br>0x01C |          |    |                                          |    |    |   |   | Register Name<br>SPIMIS |   |   |   |   |   |       |       | Total Reset Value<br>0x0000 |         |  |  |
|--------|-------------------------|----------|----|------------------------------------------|----|----|---|---|-------------------------|---|---|---|---|---|-------|-------|-----------------------------|---------|--|--|
| Bit    | 15                      | 14       | 13 | 12                                       | 11 | 10 | 9 | 8 | 7                       | 6 | 5 | 4 | 3 | 2 | 1     | 0     |                             |         |  |  |
| Name   | reserved                |          |    |                                          |    |    |   |   |                         |   |   |   |   |   | txmis | rxmis | rtrmis                      | rrormis |  |  |
| Reset  | 0                       | 0        | 0  | 0                                        | 0  | 0  | 0 | 0 | 0                       | 0 | 0 | 0 | 0 | 0 | 0     | 0     |                             |         |  |  |
| Bits   | Access                  | Name     |    | Description                              |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [15:4] | RO                      | reserved |    | Reserved                                 |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [3]    | RO                      | txmis    |    | Masked TX FIFO interrupt status          |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [2]    | RO                      | rxmis    |    | Masked RX FIFO interrupt status          |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [1]    | RO                      | rtrmis   |    | Masked RX timeout interrupt status       |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |
| [0]    | RO                      | rrormis  |    | Masked RX FIFO overflow interrupt status |    |    |   |   |                         |   |   |   |   |   |       |       |                             |         |  |  |

## SPIICR

SPIICR is an interrupt clear register. Writing 1 to the corresponding bit clear an interrupt, and writing 0 has no effect.



| Offset Address |        |          |    |    |                             |        |   |   |   | Register Name |        |   |   |   | Total Reset Value |   |  |  |  |
|----------------|--------|----------|----|----|-----------------------------|--------|---|---|---|---------------|--------|---|---|---|-------------------|---|--|--|--|
| Bit            | 0x020  |          |    |    |                             | SPIICR |   |   |   |               | 0x0000 |   |   |   |                   |   |  |  |  |
| Name           | 15     | 14       | 13 | 12 | 11                          | 10     | 9 | 8 | 7 | 6             | 5      | 4 | 3 | 2 | 1                 | 0 |  |  |  |
| reserved       |        |          |    |    |                             |        |   |   |   |               | rtic   |   |   |   | roric             |   |  |  |  |
| Reset          | 0      | 0        | 0  | 0  | 0                           | 0      | 0 | 0 | 0 | 0             | 0      | 0 | 0 | 0 | 0                 |   |  |  |  |
| Bits           | Access | Name     |    |    | Description                 |        |   |   |   |               |        |   |   |   |                   |   |  |  |  |
| [15:2]         | RO     | reserved |    |    | Reserved                    |        |   |   |   |               |        |   |   |   |                   |   |  |  |  |
| [1]            | RO     | rtic     |    |    | RX timeout interrupt clear  |        |   |   |   |               |        |   |   |   |                   |   |  |  |  |
| [0]            | RO     | roric    |    |    | RX overflow interrupt clear |        |   |   |   |               |        |   |   |   |                   |   |  |  |  |

## SPITXFIFOOCR

SPITXFIFOOCR is a TX FIFO control register.

| Offset Address |        |           |    |    |                                                                                                                                                                                                                                            |              |   |   |   | Register Name |           |   |   |   | Total Reset Value |   |  |  |  |
|----------------|--------|-----------|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---|---|---|---------------|-----------|---|---|---|-------------------|---|--|--|--|
| Bit            | 0x028  |           |    |    |                                                                                                                                                                                                                                            | SPITXFIFOOCR |   |   |   |               | 0x0009    |   |   |   |                   |   |  |  |  |
| Name           | 15     | 14        | 13 | 12 | 11                                                                                                                                                                                                                                         | 10           | 9 | 8 | 7 | 6             | 5         | 4 | 3 | 2 | 1                 | 0 |  |  |  |
| reserved       |        |           |    |    |                                                                                                                                                                                                                                            |              |   |   |   |               | txintsize |   |   |   | dmatxbysize       |   |  |  |  |
| Reset          | 0      | 0         | 0  | 0  | 0                                                                                                                                                                                                                                          | 0            | 0 | 0 | 0 | 0             | 0         | 0 | 1 | 0 | 0                 | 1 |  |  |  |
| Bits           | Access | Name      |    |    | Description                                                                                                                                                                                                                                |              |   |   |   |               |           |   |   |   |                   |   |  |  |  |
| [15:6]         | RW     | reserved  |    |    | Reserved                                                                                                                                                                                                                                   |              |   |   |   |               |           |   |   |   |                   |   |  |  |  |
| [5:3]          | RW     | txintsize |    |    | Threshold for triggering a TX FIFO interrupt. When the amount of data in the TX FIFO is less than or equal to the value of TXINTSize, TXRIS is valid.<br>000: 1<br>001: 4<br>010: 8<br>011: 16<br>100: 32<br>101: 64<br>110: 64<br>111: 64 |              |   |   |   |               |           |   |   |   |                   |   |  |  |  |



|       |    |          |          |  |
|-------|----|----------|----------|--|
| [2:0] | RO | reserved | Reserved |  |
|-------|----|----------|----------|--|

## SPIRXFIFOOCR

SPIRXFIFOOCR is an RX FIFO control register.

| Offset Address<br>0x02C |          |           |    |                                                                                                                                                                                                                                                                                  |    |    |   |   |   | Register Name<br>SPIRXFIFOOCR |           |   |   | Total Reset Value<br>0x0009 |   |          |  |
|-------------------------|----------|-----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|-------------------------------|-----------|---|---|-----------------------------|---|----------|--|
| Bit                     | 15       | 14        | 13 | 12                                                                                                                                                                                                                                                                               | 11 | 10 | 9 | 8 | 7 | 6                             | 5         | 4 | 3 | 2                           | 1 | 0        |  |
| Name                    | reserved |           |    |                                                                                                                                                                                                                                                                                  |    |    |   |   |   |                               | rxintsize |   |   |                             |   | dmarsize |  |
| Reset                   | 0        | 0         | 0  | 0                                                                                                                                                                                                                                                                                | 0  | 0  | 0 | 0 | 0 | 0                             | 0         | 0 | 1 | 0                           | 0 | 1        |  |
| Bits                    | Access   | Name      |    | Description                                                                                                                                                                                                                                                                      |    |    |   |   |   |                               |           |   |   |                             |   |          |  |
| [15:6]                  | RW       | reserved  |    | Reserved                                                                                                                                                                                                                                                                         |    |    |   |   |   |                               |           |   |   |                             |   |          |  |
| [5:3]                   | RW       | rxintsize |    | Threshold for triggering an RX FIFO interrupt. When the amount of data in the RX FIFO is greater than or equal to the value of (256 - RXINTSize), RXRIS is valid and its length is 16 bits.<br>000: 1<br>001: 4<br>010: 8<br>011: 16<br>100: 32<br>101: 64<br>110: 64<br>111: 64 |    |    |   |   |   |                               |           |   |   |                             |   |          |  |
| [2:0]                   | RO       | reserved  |    | Reserved                                                                                                                                                                                                                                                                         |    |    |   |   |   |                               |           |   |   |                             |   |          |  |

## 11.7 USB 2.0

### 11.7.1 Overview

The USB 2.0 host controller supports the high-speed (480 Mbit/s), full-speed (12 Mbit/s), and low-speed (1.5 Mbit/s) data transfer modes. It also fully complies with the USB 2.0, OHCI, and EHCI protocols. The USB 2.0 host controller has a root hub that is a part of the USB system and is used to extend the USB port. Most hardware logic of the USB 2.0 host controller supports the following functions:

- Controls and processes data transfer.
- Parses data packets and packages data.
- Encodes and decodes the signals transmitted over the USB port.
- Provides interfaces (such as the interrupt vector interface) for the driver.

The USB 2.0 device controller supports the high-speed (480 Mbit/s) and full-speed (12 Mbit/s) data transfer modes. Port 0 allows intelligent switchover between the host and device.

## 11.7.2 Function Description

### Logic Block Diagram

[Figure 11-41](#) shows the logic block diagram of the USB 2.0 host controller.

**Figure 11-41** Logic block diagram of the USB 2.0 host controller



[Figure 11-42](#) shows the logic block diagram of the USB 2.0 device controller.

**Figure 11-42** Logical block diagram of the USB 2.0 device controller

## Typical Applications

Figure 11-43 shows the reference design of the USB 2.0 host controller.



### CAUTION

- The single-ended impedance of DP or DM is  $45\ \Omega \pm 1\%$ , and no extra matched resistor is required.
- The precision of the REXT resistor is  $\pm 1\%$ .
- If high-speed electro static discharge (ESD) components are used, 1 pF capacitors are recommended.

**Figure 11-43** Reference design of the USB 2.0 module



## Features

The USB 2.0 host controller has the following features:

- Complies with the USB 2.0 standard.
- Complies with the OHCI and EHCI protocols.
- Supports high-speed, full-speed, and low-speed devices.
- Supports low-power solutions.
- Supports four basic data transfer modes: control transfer, bulk transfer, isochronous transfer, and interrupt transfer.
- Supports a maximum of 127 devices by using USB hubs.

The USB 2.0 device controller has the following features:

- Complies with the USB 2.0 standard.
- Supports the high-speed and full-speed modes.
- Supports two basic data transfer modes: control transfer and bulk transfer.

## Function Implementation

The USB 2.0 module supports the following four standard transfer modes:

- Control transfer

This mode applies to the data transfer between endpoints 0 of the USB host and USB device. For the USB devices of specific models, other endpoints may be used. The control transfer is bidirectional and the transferred data amount is small. Depending on the device and transfer speed, 8-byte data, 16-byte data, 32-byte data, or 64-byte data can be transferred.

- Bulk transfer

This mode is typically used when a large amount of data is transmitted with no requirements on the bandwidth and time interval. This mode is the best choice when the transfer speed is very low and many data transfers are delayed. Bulk transfer is performed after all other types of data transfers are complete. This mode ensures that data is transferred between the USB host and USB device without errors by using an error detection and retransmission mechanism.

- Isochronous transfer

This mode applies to the stream data transfer with strict time requirements and high error tolerance or the instant data transfer at a constant transfer rate. This mode provides a specific bandwidth and time interval.

- Interrupt transfer

This mode applies to transfer of small-sized, scattered, and unpredictable data. In this mode, the device is regularly queried for interrupt data to be sent. The query frequency ranges from 1 ms to 255 ms and it depends on the device endpoint mode. Typically, the interrupt transfer is unidirectional and only input is available for the USB host.

### 11.7.3 Operating Mode

#### Controlling the Clock Gating

If the USB 2.0 host controller is not used, its clocks can be disabled to reduce power consumption.



The working clock is disabled as follows:

**Step 1** Set the corresponding ports to suspend mode by using the drivers complying with the EHCI and OHCI protocols.

**Step 2** Set PERI\_CRG46 bit[6:0] and PERI\_CRG102 bit[5:0] to 0.

----End

The working clock is enabled as follows:

**Step 1** Set PERI\_CRG46 bit[6:0] and PERI\_CRG102 bit[5:0] to 1 to enable the clocks of the USB 2.0 host controller.

**Step 2** Enable ports to exit the suspend mode by using the drivers complying with the EHCI and OHCI protocols.

----End

## Deasserting Reset

The USB controller and PHY are reset after power-on by default. The reset is deasserted as follows:

**Step 1** Delay for at least 10  $\mu$ s.

**Step 2** Write 0 to PERI\_CRG100 bit[8] and PERI\_CRG47 bit[8] to deassert the global reset on the USB PHY.

**Step 3** Wait 250  $\mu$ s until the internal PLL of the PHY is stable.

**Step 4** Read PERI\_CRG91 bit[2:0]. If the bits are all 1s, go to step 6; otherwise, go to step 5.

**Step 5** Write 1 to PERI\_CRG100 bit[8] and PERI\_CRG47 bit[8] to reset the PHY, wait 10  $\mu$ s, and then go to step 2.

**Step 6** Write 0 to PERI\_CRG46[17:12] and PERI\_CRG102[16:12] to deassert resets on each part.

----End

## Separately Resetting Ports During the Working Process

Ports are separately reset during the working process as follows:

**Step 1** Write 1 to PERI\_CRG102 bit[5], PERI\_CRG46 bit[14], or PERI\_CRG46 bit[13] (corresponding to port 2, port 1, and port 0 respectively) to soft-reset the USB controller port.

**Step 2** Write 1 to PERI\_CRG100 bit[9], PERI\_CRG47 bit[11], or PERI\_CRG47 bit[9] (corresponding to port 2, port 1, and port 0 respectively) to soft-reset the USB PHY port.

**Step 3** Wait 200  $\mu$ s, and then write 0 to PERI\_CRG100 bit[9], PERI\_CRG47 bit[11], or PERI\_CRG47 bit[9] (corresponding to port 2, port 1, and port 0 respectively) to deassert the reset on the USB PHY port.

**Step 4** Write 0 to PERI\_CRG102 bit[5], PERI\_CRG46 bit[14], or PERI\_CRG46 bit[13] (corresponding to port 2, port 1, and port 0 respectively) to deassert the reset on the USB controller port.

----End



## Suspending and Resuming a Port

Suspending a port: A port enters the suspend mode after software enables the suspend mode by configuring the EHCI/OHCI register.

Resuming a port: After software enables the port to exit the suspend mode by configuring the EHCI/OHCI register, it can initiate a USB operation only after at least 250  $\mu$ s delay.

## 11.7.4 Summary of USB Host Register

Table 11-13 describes USB host registers.

- Base address for port 0 and port 1 registers: 0xF989\_0000
- Base address for port 2 registers: 0xF993\_0000

Table 11-13 Summary of USB host registers

| Offset Address | Register  | Description                                  | Page                   |
|----------------|-----------|----------------------------------------------|------------------------|
| 0x90           | INSNREG00 | Micro-frame length configuration register    | <a href="#">11-99</a>  |
| 0x94           | INSNREG01 | PBUF out/in threshold configuration register | <a href="#">11-100</a> |
| 0x98           | INSNREG02 | PBUF depth configuration register            | <a href="#">11-100</a> |
| 0x9C           | INSNREG03 | Interrupt memory transfer enable register    | <a href="#">11-101</a> |
| 0xA0           | INSNREG04 | Debug register                               | <a href="#">11-101</a> |
| 0xA4           | INSNREG05 | Control and status register                  | <a href="#">11-102</a> |
| 0xA8           | INSNREG06 | AHB error status register                    | <a href="#">11-103</a> |
| 0xAC           | INSNREG07 | AHB error address register                   | <a href="#">11-104</a> |

## 11.7.5 Description of USB Host Registers

### INSNREG00

INSNREG00 is a micro-frame length configuration register.

| Bit     | Offset Address |          |   |   |   |             |   |   |   |   |   |   |   |   |   |   | Register Name |   |   |   |     |   |   |   | Total Reset Value |   |   |   |    |   |   |   |  |  |  |  |  |
|---------|----------------|----------|---|---|---|-------------|---|---|---|---|---|---|---|---|---|---|---------------|---|---|---|-----|---|---|---|-------------------|---|---|---|----|---|---|---|--|--|--|--|--|
|         | 0x90           |          |   |   |   |             |   |   |   |   |   |   |   |   |   |   | INSNREG00     |   |   |   |     |   |   |   | 0x0000_0000       |   |   |   |    |   |   |   |  |  |  |  |  |
| Name    | reserved       |          |   |   |   |             |   |   |   |   |   |   |   |   |   |   | debug         |   |   |   | val |   |   |   |                   |   |   |   | en |   |   |   |  |  |  |  |  |
| Reset   | 0              | 0        | 0 | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0             | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0  | 0 | 0 | 0 |  |  |  |  |  |
| Bits    | Access         | Name     |   |   |   | Description |   |   |   |   |   |   |   |   |   |   |               |   |   |   |     |   |   |   |                   |   |   |   |    |   |   |   |  |  |  |  |  |
| [31:20] | -              | reserved |   |   |   | Reserved    |   |   |   |   |   |   |   |   |   |   |               |   |   |   |     |   |   |   |                   |   |   |   |    |   |   |   |  |  |  |  |  |



|         |    |       |                                                                                                                                                                                                                                                               |
|---------|----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19:14] | RW | debug | For debugging only                                                                                                                                                                                                                                            |
| [13:1]  | RW | val   | Micro-frame counter<br>This field is used only for simulation. In normal cases, the micro-frame length is 125 μs defined in the protocol. During simulation, the micro-frame length can be shortened by configuring this field to reduce the simulation time. |
| [0]     | RW | en    | Register enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                  |

## INSNREG01

INTNREG01 is a PBUF out/in threshold register.

|         | Offset Address<br>0x94 |               |    |    |    |                                                                                                                                            |    |    |    |    |    |    |    |    |    |    | Register Name<br>INSNREG01 |    |    |    |    |    |   |   | Total Reset Value<br>0x0020_0020 |   |   |   |   |   |   |   |  |
|---------|------------------------|---------------|----|----|----|--------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|--|
| Bit     | 31                     | 30            | 29 | 28 | 27 | 26                                                                                                                                         | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name    | out_threshold          |               |    |    |    |                                                                                                                                            |    |    |    |    |    |    |    |    |    |    | in_threshold               |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| Reset   | 0                      | 0             | 0  | 0  | 0  | 0                                                                                                                                          | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0                          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 1 | 0 | 0 | 0 | 0 |   |  |
| Bits    | Access                 | Name          |    |    |    | Description                                                                                                                                |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| [31:16] | RW                     | out_threshold |    |    |    | TX threshold<br>If the data amount in the PBUF is above the TX threshold, data starts to be transmitted. The depth is measured by 32 bits. |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| [15:0]  | RW                     | in_threshold  |    |    |    | RX threshold<br>If the data amount in the PBUF is above the RX threshold, data is read from the PBUF. The depth is measured by 32 bits.    |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |

## INSNREG02

INSNREG02 is a PBUF depth configuration register.

|         | Offset Address<br>0x98 |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | Register Name<br>INSNREG02 |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0080 |   |   |   |   |   |   |   |
|---------|------------------------|----------|----|----|----|-------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                     | 30       | 29 | 28 | 27 | 26          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved               |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | pbuf_depth                 |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| Reset   | 0                      | 0        | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1                                | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits    | Access                 | Name     |    |    |    | Description |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [31:12] | -                      | reserved |    |    |    | Reserved    |    |    |    |    |    |    |    |    |    |    |                            |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |



|        |    |            |                                               |
|--------|----|------------|-----------------------------------------------|
| [11:0] | RW | pbuf_depth | PBUF depth. The depth is measured by 32 bits. |
|--------|----|------------|-----------------------------------------------|

## INSNREG03

INSNREG03 is an interrupt memory transfer enable register.

|         | Offset Address 0x9C |          |                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name INSNREG03 |      |     |       |        |    |   |   | Total Reset Value 0x0000_0001 |   |   |   |        |   |   |   |
|---------|---------------------|----------|---------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|------|-----|-------|--------|----|---|---|-------------------------------|---|---|---|--------|---|---|---|
| Bit     | 31                  | 30       | 29                                                            | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                      | 14   | 13  | 12    | 11     | 10 | 9 | 8 | 7                             | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
| Name    | reserved            |          |                                                               |    |    |    |    |    |    |    |    |    |    |    |    |    | dis                     | ctrl | val | fetch | offset |    |   |   |                               |   |   |   | brk_en |   |   |   |
| Reset   | 0                   | 0        | 0                                                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0    | 0   | 0     | 0      | 0  | 0 | 0 | 0                             | 0 | 0 | 0 | 0      | 1 |   |   |
| Bits    | Access              | Name     | Description                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [31:15] | -                   | reserved | Reserved                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [14]    | RW                  | dis      | 256 MHz clock check enable<br>0: disabled<br>1: enabled       |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [13]    | RW                  | ctrl     | Line state ignore during TESTSE0 NAK                          |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [12:10] | RW                  | val      | TX-TX turnaround delay attach                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [9]     | RW                  | fetch    | Periodic frames list RX                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [8:1]   | RW                  | offset   | Available time offset                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |
| [0]     | RO                  | brk_en   | Interrupt memory transfer enable<br>0: disabled<br>1: enabled |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |      |     |       |        |    |   |   |                               |   |   |   |        |   |   |   |

## INSNREG04

INSNREG04 is a debug register.



|        | Offset Address                                                                                                                                                          | Register Name      | Total Reset Value                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|---------|----------------|----------|--------------------|-------------|-------------|
| Bit    | 0xA0                                                                                                                                                                    | INSNREG04          | 0x0000_0000                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| Name   | reserved                                                                                                                                                                |                    |                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  | auto_en | nak_reldfix_en | reserved | scaledwn_enum_time | hccparam_en | hcsparam_en |
| Reset  | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                    |                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| Bits   | Access                                                                                                                                                                  | Name               | Description                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [31:6] | -                                                                                                                                                                       | reserved           | Reserved                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [5]    | RW                                                                                                                                                                      | auto_en            | Automatic feature enable<br>0: enabled (default). The suspend signal is valid when the run/stop bit is reset by software, but the hchalted bit is not set.<br>1: disabled. The port is not suspended when software clears the run/stop bit. |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [4]    | RW                                                                                                                                                                      | nak_reldfix_en     | NAK reload enable<br>0: enabled<br>1: disable                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [3]    | -                                                                                                                                                                       | reserved           | Reserved                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [2]    | RW                                                                                                                                                                      | scaledwn_enum_time | Port enumeration time scale-down enable<br>0: disabled<br>1: enabled                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [1]    | RW                                                                                                                                                                      | hccparam_en        | HCCPARAMS register write enable<br>0: disabled<br>1: enabled                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |
| [0]    | RW                                                                                                                                                                      | hcsparam_en        | HCSPARAMS register write enable<br>0: disabled<br>1: enabled                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |         |                |          |                    |             |             |

## INSNREG05

INSNREG05 is a control and status register. It is used to read or write to PHY registers.



| Offset Address |          |                |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | Register Name |       |       |    |                |          |    |             | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------------|----|-------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|-------|-------|----|----------------|----------|----|-------------|-------------------|---|---|---|---|---|---|---|---|
| 0xA4           |          |                |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    | INSNREG05     |       |       |    |                |          |    |             | 0x4000_1000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28                                                                                                          | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15    | 14    | 13 | 12             | 11       | 10 | 9           | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |               | vbusy | vport |    | vcontrol_loadm | vcontrol |    | hccparam_en |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 1              | 0  | 0                                                                                                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0     | 0     | 0  | 1              | 0        | 0  | 0           | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name           |    | Description                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [31:18]        | -        | reserved       |    | Reserved                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [17]           | RO       | vbusy          |    | The value 1 indicates that hardware is writing data. This bit is cleared only when the process is complete. |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [16:13]        | RW       | vport          |    | Port ID. It cannot exceed the supported number of ports.                                                    |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [12]           | RW       | vcontrol_loadm |    | Load enable<br>0: enabled<br>1: disable                                                                     |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [11:8]         | RW       | vcontrol       |    | Port control signal                                                                                         |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |
| [7:0]          | RO       | hccparam_en    |    | Port status signal                                                                                          |    |    |    |    |    |    |    |    |    |    |    |               |       |       |    |                |          |    |             |                   |   |   |   |   |   |   |   |   |

## INSNREG06

INSNREG06 is an AHB error status register.



INSNREG07

INSNREG07 is an AHB error address register.

| Offset Address |          |          |    |           |                                                          |    |    | Register Name |    |    |    |             |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|-----------|----------------------------------------------------------|----|----|---------------|----|----|----|-------------|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0AC          |          |          |    | INSNREG07 |                                                          |    |    |               |    |    |    | 0x0000_0000 |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28        | 27                                                       | 26 | 25 | 24            | 23 | 22 | 21 | 20          | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | err_addr |          |    |           |                                                          |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0         | 0                                                        | 0  | 0  | 0             | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |           | Description                                              |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RO       | err_addr |    |           | Address during control transfer when an AHB error occurs |    |    |               |    |    |    |             |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



## 11.7.6 Offset Address Variables for USB Device Registers

Table 11-14 describes the value range and meaning of the variables in the offset addresses for USB device registers.

**Table 11-14** Register variables

| Variable | Value Range | Description     |
|----------|-------------|-----------------|
| FIFO_num | 0–14        | Number of FIFOs |
| n        | 0–15        | Endpoint n      |

## 11.7.7 Summary of USB Device Registers

Table 11-15 describes USB device registers.

**Table 11-15** Summary of USB device registers (base address: 0xF98C0000)

| Offset Address | Register  | Description                                                     | Page                   |
|----------------|-----------|-----------------------------------------------------------------|------------------------|
| 0x0000         | GOTGCTL   | Device behavior control and status query register               | <a href="#">11-107</a> |
| 0x0004         | GOTGINT   | Device interrupt generation indicator/clear register            | <a href="#">11-110</a> |
| 0x0008         | GAHBCFG   | AHB configuration register                                      | <a href="#">11-110</a> |
| 0x000C         | GUSBCFG   | USB configuration register                                      | <a href="#">11-112</a> |
| 0x0010         | GRSTCTL   | Reset hardware feature register                                 | <a href="#">11-115</a> |
| 0x0014         | GINTSTS   | System interrupt register                                       | <a href="#">11-117</a> |
| 0x0018         | GINTMSK   | System interrupt mask register                                  | <a href="#">11-120</a> |
| 0x001C         | GRXSTSR   | RX status debug read register                                   | <a href="#">11-124</a> |
| 0x0020         | GRXSTSP   | RX status read&pop register                                     | <a href="#">11-125</a> |
| 0x0024         | GRXFSIZ   | RX FIFO size configuration register                             | <a href="#">11-126</a> |
| 0x0028         | GNPTXFSIZ | Non-periodic TX FIFO size configuration register                | <a href="#">11-126</a> |
| 0x002C         | GNPTXSTS  | Non-periodic TX FIFO and non-periodic TX request queue register | <a href="#">11-126</a> |
| 0x0030         | GI2CCTL   | I <sup>2</sup> C access register                                | <a href="#">11-127</a> |
| 0x0034         | GPVNDCTL  | PHY vendor control register                                     | <a href="#">11-129</a> |
| 0x0038         | GPIO      | GPIO register                                                   | <a href="#">11-130</a> |
| 0x003C         | GUID      | User ID query register                                          | <a href="#">11-130</a> |
| 0x0040         | GSNPSID   | Synopsys ID query register                                      | <a href="#">11-130</a> |
| 0x0044         | GHWCFG1   | User hardware configuration register 1                          | <a href="#">11-131</a> |



| Offset Address             | Register      | Description                                             | Page                   |
|----------------------------|---------------|---------------------------------------------------------|------------------------|
| 0x0048                     | GHWCFG2       | User hardware configuration register 2                  | <a href="#">11-131</a> |
| 0x004C                     | GHWCFG3       | User hardware configuration register 3                  | <a href="#">11-133</a> |
| 0x0050                     | GHWCFG4       | User hardware configuration register 4                  | <a href="#">11-135</a> |
| 0x0054                     | GLPMCFG       | Link power management (LPM) configuration register      | <a href="#">11-137</a> |
| 0x0058                     | GPWRDN        | Power-down register                                     | <a href="#">11-139</a> |
| 0x005C                     | GDFIFO CFG    | DFIFO software configuration register                   | <a href="#">11-141</a> |
| 0x0060                     | GADPCTL       | ADP timer control and status register                   | <a href="#">11-142</a> |
| 0x0100                     | HPTXFSIZ      | TX FIFO configuration register                          | <a href="#">11-144</a> |
| 0x0104+0x0004×F<br>IFO_num | DPTXFSIZN     | Device periodic TX FIFO-n size register                 | <a href="#">11-144</a> |
| 0x0104+0x0004×F<br>IFO_num | DIEPTXFN      | Device IN endpoint TX FIFO size register                | <a href="#">11-145</a> |
| 0x0800                     | DCFG          | Device configuration register                           | <a href="#">11-145</a> |
| 0x0804                     | DCTL          | Device control register                                 | <a href="#">11-147</a> |
| 0x0808                     | DSTS          | Device status register                                  | <a href="#">11-149</a> |
| 0x0810                     | DIEPMSK       | Device IN endpoint common interrupt mask register       | <a href="#">11-149</a> |
| 0x0814                     | DOEPMSK       | Device OUT endpoint common interrupt mask register      | <a href="#">11-151</a> |
| 0x0818                     | DAINT         | Interrupt register for all device endpoints             | <a href="#">11-152</a> |
| 0x081C                     | DAINTMSK      | Interrupt mask register for all device endpoints        | <a href="#">11-153</a> |
| 0x0820                     | DTKNQR1       | Device IN token sequence learning queue read register 1 | <a href="#">11-153</a> |
| 0x0824                     | DTKNQR2       | Device IN token sequence learning queue read register 2 | <a href="#">11-154</a> |
| 0x0830                     | DTKNQR3       | Device IN token sequence learning queue read register 3 | <a href="#">11-155</a> |
| 0x0834                     | DTKNQR4       | Device IN token sequence learning queue read register 4 | <a href="#">11-155</a> |
| 0x0828                     | DVBUSDIS      | Device VBUS discharge time register                     | <a href="#">11-155</a> |
| 0x082C                     | DVBUSPULSE    | Device VBUS pulsing time register                       | <a href="#">11-156</a> |
| 0x0830                     | DTHRCTL       | Device threshold control register                       | <a href="#">11-156</a> |
| 0x0834                     | DIEPEMPMSK    | Device IN endpoint FIFO empty interrupt mask register   | <a href="#">11-157</a> |
| 0x0838                     | DEACHINT      | Interrupt register for each device endpoint             | <a href="#">11-158</a> |
| 0x083C                     | DEACHINTMSK   | Interrupt mask register for each device endpoint        | <a href="#">11-158</a> |
| 0x0840 + (0x0004×n)        | DIEPEACHMSK_N | Interrupt register for device IN endpoint n             | <a href="#">11-159</a> |



| Offset Address        | Register      | Description                                             | Page                   |
|-----------------------|---------------|---------------------------------------------------------|------------------------|
| 0x0880 + (0x0004 x n) | DOEPEACHMS KN | Interrupt register for device OUT endpoint $n$          | <a href="#">11-160</a> |
| 0x0900                | DIEPCTL0      | Control register for device control IN endpoint 0       | <a href="#">11-162</a> |
| 0x0B00                | DOEPCTL0      | Control register for device control OUT endpoint 0      | <a href="#">11-163</a> |
| 0x0900 + (0x0020 x n) | DIEPCTLN      | Control register for device IN endpoint $n$             | <a href="#">11-165</a> |
| 0x0B00 + (0x0020 x n) | DOEPCTLN      | Control register for device OUT endpoint $n$            | <a href="#">11-166</a> |
| 0x0908 + (0x0020 x n) | DIEPINTn      | Interrupt register for device IN endpoint $n$           | <a href="#">11-168</a> |
| 0x0B08 + (0x0020 x n) | DOEPINTn      | Interrupt register for device OUT endpoint $n$          | <a href="#">11-171</a> |
| 0x0910                | DIEPTSIZ0     | Transfer size register for device IN endpoint 0         | <a href="#">11-173</a> |
| 0x0B10                | DOEPTSIZ0     | Transfer size register for device OUT endpoint 0        | <a href="#">11-174</a> |
| 0x0910 + (0x0020 x n) | DIEPTSIZn     | Transfer size register for device IN endpoint $n$       | <a href="#">11-175</a> |
| 0x0B10 + (0x0020 x n) | DOEPTSIZn     | Transfer size register for device OUT endpoint $n$      | <a href="#">11-175</a> |
| 0x0914 + (0x0020 x n) | DIEPDMAN      | DMA address register for device IN endpoint $n$         | <a href="#">11-176</a> |
| 0x0B14 + (0x0020 x n) | DOEPDMAN      | DMA address register for device OUT endpoint $n$        | <a href="#">11-177</a> |
| 0x091C + (0x0020 x n) | DIEPDMABN     | DMA buffer address register for device IN endpoint $n$  | <a href="#">11-177</a> |
| 0x0B1C + (0x0020 x n) | DOEPDMABN     | DMA buffer address register for device OUT endpoint $n$ | <a href="#">11-178</a> |
| 0x0938                | DTXFSTS $n$   | Device IN endpoint TX FIFO status register              | <a href="#">11-178</a> |

## 11.7.8 Description of USB Device Registers

### GOTGCTL

GOTGCTL is a device behavior control and status query register.



|         | Offset Address<br>0x0000 |             |    |                                                                                                              |             |    |    |    |          |        |         |         | Register Name<br>GOTGCTL |          |          |    |    |    |            |               |        |          |              |            | Total Reset Value<br>0x04C1_0000 |              |             |               |        |           |   |   |  |  |  |  |
|---------|--------------------------|-------------|----|--------------------------------------------------------------------------------------------------------------|-------------|----|----|----|----------|--------|---------|---------|--------------------------|----------|----------|----|----|----|------------|---------------|--------|----------|--------------|------------|----------------------------------|--------------|-------------|---------------|--------|-----------|---|---|--|--|--|--|
| Bit     | 31                       | 30          | 29 | 28                                                                                                           | 27          | 26 | 25 | 24 | 23       | 22     | 21      | 20      | 19                       | 18       | 17       | 16 | 15 | 14 | 13         | 12            | 11     | 10       | 9            | 8          | 7                                | 6            | 5           | 4             | 3      | 2         | 1 | 0 |  |  |  |  |
| Name    | reserved                 |             |    |                                                                                                              | multvalidbc |    |    |    | reserved | otgver | bsesvld | asesvld | dbnctime                 | conidsts | reserved |    |    |    | devhnpnpen | hstsethnpnpen | hmpreq | hstneges | bvaliddovval | bvaliddovn | avaliddovn                       | avaliddovval | vbvaliddovn | vbvaliddovval | sesreq | sesreqscs |   |   |  |  |  |  |
| Reset   | 0                        | 0           | 0  | 0                                                                                                            | 0           | 1  | 0  | 0  | 1        | 1      | 0       | 0       | 0                        | 0        | 1        | 0  | 0  | 0  | 0          | 0             | 0      | 0        | 0            | 0          | 0                                | 0            | 0           | 0             | 0      | 0         |   |   |  |  |  |  |
| Bits    | Access                   | Name        |    | Description                                                                                                  |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [31:27] | -                        | reserved    |    | Reserved                                                                                                     |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [26:22] | RO                       | multvalidbc |    | BC ACA input<br>Bit[26]: rid_float<br>Bit[25]: rid_gnd<br>Bit[24]: rid_a<br>Bit[23]: rid_b<br>Bit[22]: rid_c |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [21]    | RO                       | reserved    |    | Reserved                                                                                                     |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [20]    | RW                       | otgver      |    | Device version<br>0: version 1.3<br>1: version 2.0                                                           |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [19]    | RO                       | bsesvld     |    | Transceiver status in device mode<br>0: B_session is invalid.<br>1: B_session is valid.                      |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [18]    | RO                       | asesvld     |    | Transceiver status in host mode<br>0: A_session is invalid.<br>1: A_session is valid.                        |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [17]    | RO                       | dbnctime    |    | Dejitter time<br>0: long dejitter time<br>1: short dejitter time                                             |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [16]    | RO                       | conidsts    |    | USB_ID status<br>0: The device works in A-device mode.<br>1: The device works in B-device mode.              |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [15:12] | RO                       | reserved    |    | Reserved                                                                                                     |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |
| [11]    | RW                       | devhnpnpen  |    | Device Host Negotiation Protocol (HNP) enable<br>0: disabled<br>1: enabled                                   |             |    |    |    |          |        |         |         |                          |          |          |    |    |    |            |               |        |          |              |            |                                  |              |             |               |        |           |   |   |  |  |  |  |



|      |    |                |                                                                                                                  |
|------|----|----------------|------------------------------------------------------------------------------------------------------------------|
| [10] | RW | hstsethnpn     | Host HNP enable<br>0: disabled<br>1: enabled                                                                     |
| [9]  | RW | hnpreq         | HNP request<br>0: no request<br>1: request                                                                       |
| [8]  | RO | hstnegscs      | Host negotiation indicator<br>0: Host negotiation fails.<br>1: Host negotiation succeeds.                        |
| [7]  | RW | bvalidovval    | Bvalid setting<br>0: Bvalid = 0<br>1: Bvalid = 1<br>This bit is valid when GOTGCTL[bvalidoven] is 1.             |
| [6]  | RW | bvalidoven     | Bvalid signal overwrite enable<br>0: Bvalid can be overwritten.<br>1: Bvalid cannot be overwritten.              |
| [5]  | RW | avalidovval    | Avalid setting<br>0: Avalid = 0<br>1: Avalid = 1<br>This bit is valid when GOTGCTL[avalidoven] is 1.             |
| [4]  | RW | avalidoven     | Avalid signal overwrite enable<br>0: Avalid can be overwritten.<br>1: Avalid cannot be overwritten.              |
| [3]  | RW | vbusvalidovval | vbusvalid setting<br>0: vbusvalid = 0<br>1: vbusvalid = 1<br>This bit is valid when GOTGCTL[vbusvalidoven] is 1. |
| [2]  | RW | vbusvalidoven  | vbusvalid signal overwrite enable<br>0: vbusvalid can be overwritten.<br>1: vbusvalid cannot be overwritten.     |
| [1]  | RW | sesreq         | Session request<br>0: no request<br>1: request                                                                   |
| [0]  | RO | sesreqscs      | Session request status<br>0: failed<br>1: succeeded                                                              |



## GOTGINT

GOTGINT is a device interrupt generation indicator/clear register.

|         | Offset Address |                 |    |                                                                                                                                                                                   |    |    |    |    |    |    | Register Name |             |           |          |    |    |    |    |    |                 | Total Reset Value |          |   |   |   |           |          |   |   |   |   |   |
|---------|----------------|-----------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---------------|-------------|-----------|----------|----|----|----|----|----|-----------------|-------------------|----------|---|---|---|-----------|----------|---|---|---|---|---|
|         | 0x0004         |                 |    |                                                                                                                                                                                   |    |    |    |    |    |    | GOTGINT       |             |           |          |    |    |    |    |    |                 | 0x0000_0000       |          |   |   |   |           |          |   |   |   |   |   |
| Bit     | 31             | 30              | 29 | 28                                                                                                                                                                                | 27 | 26 | 25 | 24 | 23 | 22 | 21            | 20          | 19        | 18       | 17 | 16 | 15 | 14 | 13 | 12              | 11                | 10       | 9 | 8 | 7 | 6         | 5        | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved       |                 |    |                                                                                                                                                                                   |    |    |    |    |    |    | dbncedone     | adevtoutchg | hstnegdet | reserved |    |    |    |    |    | hstnegsucstschn | sesreqsucstschn   | reserved |   |   |   | sesenddet | reserved |   |   |   |   |   |
| Reset   | 0              | 0               | 0  | 0                                                                                                                                                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0           | 0         | 0        | 0  | 0  | 0  | 0  | 0  | 0               | 0                 | 0        | 0 | 0 | 0 | 0         | 0        | 0 | 0 | 0 |   |   |
| Bits    | Access         | Name            |    | Description                                                                                                                                                                       |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [31:20] | RO             | reserved        |    | Reserved                                                                                                                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [19]    | RO             | dbncedone       |    | An interrupt is generated when dejitter is successful. Setting this bit to 1 clears the interrupt.<br>This bit is valid only when the HNP capable or SRP capable bit is set to 1. |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [18]    | RO             | adevtoutchg     |    | An interrupt is generated when waiting for the connection of device B times out. Setting this bit to 1 clears the interrupt.                                                      |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [17]    | RO             | hstnegdet       |    | An interrupt is generated when host negotiation is detected. Setting this bit to 1 clears the interrupt.                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [16:10] | RO             | reserved        |    | Reserved                                                                                                                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [9]     | RO             | hstnegsucstschn |    | An interrupt is generated when the host negotiation request fails or succeeds. Setting this bit to 1 clears the interrupt.                                                        |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [8]     | RO             | sesreqsucstschn |    | An interrupt is generated when the session request fails or succeeds. Setting this bit to 1 clears the interrupt.                                                                 |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [7:3]   | RO             | reserved        |    | Reserved                                                                                                                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [2]     | RO             | sesenddet       |    | An interrupt is generated when utmiotg_bvalid is deasserted. Setting this bit to 1 clears the interrupt.                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |
| [1:0]   | RO             | reserved        |    | Reserved                                                                                                                                                                          |    |    |    |    |    |    |               |             |           |          |    |    |    |    |    |                 |                   |          |   |   |   |           |          |   |   |   |   |   |

## GAHBCFG

GAHBCFG is an AHB configuration register.



|                                                                                                     | Offset Address                                                                | Register Name                                                  | Total Reset Value                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                                                 | 0x0008                                                                        | GAHBCFG                                                        | 0x0000_0000                                                                                                                                                                                                                 |
| 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | reserved                                                                      | invdescendianness ahbsingle notialldmawrit remmemsupp reserved | nptxfemplvl reserved dmaen hbstlen glblintrmsk                                                                                                                                                                              |
| Reset                                                                                               | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                                                                |                                                                                                                                                                                                                             |
| Bits                                                                                                | Access                                                                        | Name                                                           | Description                                                                                                                                                                                                                 |
| [31:25]                                                                                             | RW                                                                            | reserved                                                       | Reserved                                                                                                                                                                                                                    |
| [24]                                                                                                | RW                                                                            | invdescendianness                                              | Descriptor byte invert<br>0: The descriptor byte sequence is similar to the AHB master byte sequence.<br>1: When the AHB master byte sequence is big endian, the descriptor byte sequence is little endian, and versa vice. |
| [23]                                                                                                | RW                                                                            | ahbsingle                                                      | Transfer in DMA mode<br>0: The remaining data is transmitted based on the INCR burst size.<br>1: The remaining data is transmitted based on the single burst size.                                                          |
| [22]                                                                                                | RW                                                                            | notialldmawrit                                                 | DMA write operation notification. This bit is valid only when GAHBCFG[remmemsupp] is 1.                                                                                                                                     |
| [21]                                                                                                | RW                                                                            | remmemsupp                                                     | Remote memory support                                                                                                                                                                                                       |
| [20:8]                                                                                              |                                                                               | reserved                                                       | Reserved                                                                                                                                                                                                                    |
| [7]                                                                                                 | RW                                                                            | nptxfemplvl                                                    | Empty status level of the non-periodic TX FIFO                                                                                                                                                                              |
| [6]                                                                                                 |                                                                               | reserved                                                       | Reserved                                                                                                                                                                                                                    |
| [5]                                                                                                 | RW                                                                            | dmaen                                                          | DMA mode enable<br>0: The core works in slave mode.<br>1: The core works in DMA mode.                                                                                                                                       |



|       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4:1] | RW | hbstlen     | Burst length/type for both the external and internal DMA modes<br>In external DMA mode:<br>0000: 1 word<br>0001: 4 words<br>0010: 8 words<br>0011: 16 words<br>0100: 32 words<br>0101: 64 words<br>0110: 128 words<br>0111: 256 words<br>Other values: reserved<br>In internal DMA mode:<br>0000: Single<br>0001: INCR<br>0011: INCR4<br>0101: INCR8<br>0111: INCR16<br>Other values: reserved |
| [0]   | RW | glblintrmsk | Global interrupt mask<br>0: masked<br>1: not masked                                                                                                                                                                                                                                                                                                                                            |

## GUSBCFG

GUSBCFG is a USB configuration register.

| Bit   | Offset Address<br>0x000C |              |              |           |          |                                                                                |              |           |            |              |          |          |          |               |          |           | Register Name<br>GUSBCFG |        |          |        |        |                        |       |         | Total Reset Value<br>0x0000_1400 |   |   |   |   |   |   |   |  |  |
|-------|--------------------------|--------------|--------------|-----------|----------|--------------------------------------------------------------------------------|--------------|-----------|------------|--------------|----------|----------|----------|---------------|----------|-----------|--------------------------|--------|----------|--------|--------|------------------------|-------|---------|----------------------------------|---|---|---|---|---|---|---|--|--|
|       | 31                       | 30           | 29           | 28        | 27       | 26                                                                             | 25           | 24        | 23         | 22           | 21       | 20       | 19       | 18            | 17       | 16        | 15                       | 14     | 13       | 12     | 11     | 10                     | 9     | 8       | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Name  | corrupttxpkt             | forcedemode  | forcehstmode | txnddelay | reserved | ic_usbcap                                                                      | ulp <i>i</i> | indicator | complement | termeldpulse | reserved | ulpifsls | reserved | phylpwrclksel | reserved | usbtrdtim | lmpcap                   | srgcap | reserved | physel | fsintf | ulp <i>i</i> _utmi_sel | phyif | toutcal |                                  |   |   |   |   |   |   |   |  |  |
| Reset | 0                        | 0            | 0            | 0         | 0        | 0                                                                              | 0            | 0         | 0          | 0            | 0        | 0        | 0        | 0             | 0        | 0         | 1                        | 0      | 1        | 0      | 0      | 0                      | 0     | 0       | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |  |  |
| Bits  | Access                   | Name         |              |           |          | Description                                                                    |              |           |            |              |          |          |          |               |          |           |                          |        |          |        |        |                        |       |         |                                  |   |   |   |   |   |   |   |  |  |
| [31]  | WO                       | corrupttxpkt |              |           |          | Unexpected TX packet<br>This bit is for debugging only and is always set to 0. |              |           |            |              |          |          |          |               |          |           |                          |        |          |        |        |                        |       |         |                                  |   |   |   |   |   |   |   |  |  |



|         |    |                |                                                                                                                                                                                              |
|---------|----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [30]    | RW | forcedevmode   | Forcible device mode<br>0: common mode<br>1: forcible device mode                                                                                                                            |
| [29]    | RW | forcehstmode   | Forcible host mode<br>0: common mode<br>1: forcible host mode                                                                                                                                |
| [28]    | RW | txenddelay     | TX end delay enable<br>0: disabled<br>1: enabled                                                                                                                                             |
| [27]    | -  | reserved       | Reserved                                                                                                                                                                                     |
| [26]    | RO | ic_usbcap      | IC_USB enable<br>0: The IC_USB PHY interface is not selected.<br>1: The IC_USB PHY interface is selected.                                                                                    |
| [25]    | RW | ulpri          | UTMI+low pin interface (ULPI) protection enable<br>0: enabled<br>1: disabled                                                                                                                 |
| [24]    | RO | indicator      | Indicator pass-through<br>0: The complementary output signal is determined by the vbusvalid comparator.<br>1: The complementary output signal is not determined by the vbusvalid comparator. |
| [23]    | RW | complement     | Indicator complement<br>0: The PHY does not invert the external Vbus indicator signal.<br>1: The PHY inverts the external Vbus indicator signal.                                             |
| [22]    | RW | termseldlpulse | SRP line pulse drive<br>0: utmi_txvalid drives the line pulse.<br>1: utmi_termsel drives the line pulse.                                                                                     |
| [21:18] | -  | reserved       | Reserved                                                                                                                                                                                     |
| [17]    | RW | ulpifsls       | ULPI FS/LS select<br>0: ULPI interface<br>1: ULPI FS/LS serial interface<br>Note: Set GUSBCFG[ulpiumtisel] to 1 before setting this bit.                                                     |
| [16]    | -  | reserved       | Reserved                                                                                                                                                                                     |
| [15]    | RW | phylpwrclkSEL  | PHY low-power clock select<br>0: internal 480 MHz PLL clock<br>1: external 48 MHz clock                                                                                                      |
| [14]    | -  | reserved       | Reserved                                                                                                                                                                                     |



|         |      |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:10] | RW   | usbtrdtim     | USB turnaround time<br>0101: This field is set to this value when the MAC interface is a 16-bit UTMI+ interface.<br>1001: This field is set to this value when the MAC interface is an 8-bit UTMI+ interface<br>Other values: reserved                                                                                                                                                                                                                                                                                              |
| [9]     | RW   | hnpcap        | HNP enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [8]     | RW   | srpcap        | SRP enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [7]     | -    | reserved      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [6]     | R/RW | physel        | USB 2.0 high-speed PHY or USB 1.1 full-speed serial transceiver<br>0: USB 2.0 high-speed UTMI+ or ULPI PHY interface<br>1: USB 1.1 full-speed serial transceiver<br>If the USB 1.1 full-speed serial transceiver is not selected, this bit is always 0 and write-only.<br>If the USB 2.0 high-speed PHY is not selected, this bit is always 1 and read-only.<br>If the preceding interface types are not selected (non-zero value), this bit is used to select the interface to be activated, and this bit can be read and written. |
| [5]     | R/RW | fsintf        | Full-speed serial interface select<br>0: 6-pin unidirectional full-speed serial interface<br>1: 3-pin bidirectional full-speed serial interface<br>If the USB 1.1 full-speed serial transceiver is not selected, this bit is always 0 and write-only.<br>If the USB 1.1 full-speed interface is selected, this bit can be used to select the 3-pin or 6-pin interface and can be read and written.                                                                                                                                  |
| [4]     | R/RW | ulpi_utmi_sel | ULPI or UTMI select<br>0: UTMI+ interface<br>1: ULPI interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3]     | R/RW | phyif         | PHY interface<br>0: 8 bits<br>1: 16 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



|       |    |         |                                                                                                                                                                                                                                                                                    |
|-------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | RW | toutcal | HS/FS timeout calibration<br>High-speed operations:<br>One 30-MHz PHY clock = 16 bit times<br>One 60-MHz PHY clock = 8 bit times<br>Full speed operation:<br>One 30-MHz PHY clock = 0.4 bit times<br>One 60-MHz PHY clock = 0.2 bit times<br>One 48-MHz PHY clock = 0.25 bit times |
|-------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## GRSTCTL

GRSTCTL is a reset hardware feature register.

|         | Offset Address 0x0010 |          |          |                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    | Register Name GRSTCTL |    |        |    |    |    |         |         | Total Reset Value 0x8000_0000 |           |          |         |   |   |   |   |
|---------|-----------------------|----------|----------|-----------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|----|--------|----|----|----|---------|---------|-------------------------------|-----------|----------|---------|---|---|---|---|
| Bit     | 31                    | 30       | 29       | 28                                                                                                  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                    | 14 | 13     | 12 | 11 | 10 | 9       | 8       | 7                             | 6         | 5        | 4       | 3 | 2 | 1 | 0 |
| Name    | ahbidle               | dmareq   | reserved |                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                       |    | txfnum |    |    |    | txffish | rxffish | reserved                      | frmentrst | reserved | esfirst |   |   |   |   |
| Reset   | 1                     | 0        | 0        | 0                                                                                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                     | 0  | 0      | 0  | 0  | 0  | 0       | 0       | 0                             | 0         | 0        | 0       | 0 | 0 |   |   |
| Bits    | Access                | Name     |          | Description                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |        |    |    |    |         |         |                               |           |          |         |   |   |   |   |
| [31]    | RO                    | ahbidle  |          | AHB master idle, indicating whether the AHB master state machine is idle                            |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |        |    |    |    |         |         |                               |           |          |         |   |   |   |   |
| [30]    | RO                    | dmareq   |          | DMA request signal, indicating that the DMA request is in progress. This bit is only for debugging. |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |        |    |    |    |         |         |                               |           |          |         |   |   |   |   |
| [29:11] |                       | reserved |          | Reserved                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |                       |    |        |    |    |    |         |         |                               |           |          |         |   |   |   |   |



|        |          |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10:6] | RW       | txfnum     | <p>TX FIFO ID</p> <p>0x0:</p> <ul style="list-style-type: none"><li>• In host mode, non-periodic TX FIFOs are flushed.</li><li>• During shared FIFO operations, non-periodic TX FIFOs are flushed in device mode.</li><li>• In dedicated FIFO mode, TX FIFO 0 is flushed in device mode.</li></ul> <p>0x1:</p> <ul style="list-style-type: none"><li>• In host mode, periodic TX FIFOs are flushed.</li><li>• During shared FIFO operations, periodic TX FIFO 1 is flushed in device mode.</li><li>• In dedicated FIFO mode, TX FIFO 1 is flushed in device mode.</li></ul> <p>0x2:</p> <ul style="list-style-type: none"><li>• During shared FIFO operations, periodic TX FIFO 2 is flushed in device mode.</li><li>• In dedicated FIFO mode, TX FIFO 2 is flushed in device mode.</li></ul> <p>...</p> <p>0xF:</p> <ul style="list-style-type: none"><li>• During shared FIFO operations, periodic TX FIFO 15 is flushed in device mode.</li><li>• In dedicated FIFO mode, TX FIFO 15 is flushed in device mode.</li></ul> <p>0x10:</p> <ul style="list-style-type: none"><li>• All TX FIFOs are flushed in device or host mode.</li></ul> |
| [5]    | R_WS_S_C | txfflsh    | <p>TX FIFO flush</p> <p>This bit can be used to refresh one or all TX FIFOs but FIFOs cannot be refreshed during transaction.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [4]    | RO       | rxfflsh    | <p>RX FIFO flush</p> <p>This bit can be used to refresh all RX FIFOs.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [3]    | -        | reserved   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2]    | RO       | frmcntrrst | <p>Host frame counter reset</p> <p>This bit is used to reset the frame number counter. When the frame number counter is reset, the number of SOF frames is 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [1]    | RO       | reserved   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |



|     |    |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | RW | csftrst | <p>Core soft interrupt</p> <p>1) All interrupts and the CSR register excluding the following bits are cleared:</p> <ul style="list-style-type: none"><li>-PCGCCTL.RstPdwnModule</li><li>-PCGCCTL.GateHclk</li><li>-PCGCCTL.PwrClmp</li><li>-PCGCCTL.StopPPhyLPwrClkSelclk</li><li>-GUSBCFG.PhyLPwrClkSel</li><li>-GUSBCFG.DDRSel</li><li>-GUSBCFG.PHYSel</li><li>-GUSBCFG.FSIntf</li><li>-GUSBCFG.ULPI_UTMI_Sel</li><li>-GUSBCFG.PHYIf</li><li>-GUSBCFG.TxEndDelay</li><li>-GUSBCFG.TermSelDLPulse</li><li>-GUSBCFG.ULPIClkSusM</li><li>-GUSBCFG.ULPIAutoRes</li><li>-GUSBCFG.ULPIFsLs</li><li>-GPIO</li><li>-GPWRDN</li><li>-GADPCTL</li><li>-HCFG.FSLSPclkSel</li><li>-DCFG.DevSpd</li><li>-DCTL.SftDiscon</li></ul> <p>2) All module state machines are reset to the idle status, and all TX FIFOs and RX FIFOs are flushed.</p> <p>3) All transactions on the AHB master are interrupted as soon as possible, and all USB transactions are interrupted immediately.</p> <p>4) When the hibernation or ADP feature is enabled, the PMU module is not soft-reset by the core.</p> |
|-----|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## GINTSTS

GINTSTS is a system interrupt register.



| Bit   | Offset Address<br>0x0014 |             |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |         |        |        |         |         |                     |                     |        |        |       |             | Register Name<br>GINTSTS |            |          |        |         |           |          |            | Total Reset Value<br>0x0800_0080 |         |        |     |       |         |        |   |
|-------|--------------------------|-------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|--------|--------|---------|---------|---------------------|---------------------|--------|--------|-------|-------------|--------------------------|------------|----------|--------|---------|-----------|----------|------------|----------------------------------|---------|--------|-----|-------|---------|--------|---|
|       | 31                       | 30          | 29         | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 27      | 26      | 25     | 24     | 23      | 22      | 21                  | 20                  | 19     | 18     | 17    | 16          | 15                       | 14         | 13       | 12     | 11      | 10        | 9        | 8          | 7                                | 6       | 5      | 4   | 3     | 2       | 1      | 0 |
| Name  | wkupint                  | sessreqint  | disconnint | conidstschg                                                                                                                                                                                                                                                                                                                                                                                                                                                      | lpm_int | ptxfemp | hchint | prtint | residet | fetsusp | incomplpincompisout | incomplpincompisoin | oepint | iepint | epnis | rstrdoneint | eopf                     | isooutdrop | enumdone | usbrst | usbsusp | erly/susp | reserved | goutnakeff | ginnakeff                        | ntxtemp | rxflvl | sof | ogint | modenis | curmod |   |
| Reset | 0                        | 0           | 0          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1       | 0       | 0      | 0      | 0       | 0       | 0                   | 0                   | 0      | 0      | 0     | 0           | 0                        | 0          | 0        | 0      | 0       | 0         | 0        | 1          | 0                                | 0       | 0      | 0   | 0     | 0       | 0      |   |
| Bits  | Access                   | Name        |            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [31]  | RWSC                     | wkupint     |            | Suspend/Resume detection interrupt. Setting this bit to 1 clears the interrupt.                                                                                                                                                                                                                                                                                                                                                                                  |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [30]  | RWSC                     | sessreqint  |            | In host mode, an interrupt is generated when a device session request is detected.<br>In device mode, an interrupt is generated when utmisrp_bvalid is 1.<br>Setting this bit to 1 clears the interrupt.                                                                                                                                                                                                                                                         |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [29]  | RWSC                     | disconnint  |            | An interrupt is generated when the system detects that the device is disconnected.<br>Setting this bit to 1 clears the interrupt.                                                                                                                                                                                                                                                                                                                                |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [28]  | RWSC                     | conidstschg |            | An interrupt is generated when the slot ID changes.<br>Setting this bit to 1 clears the interrupt.                                                                                                                                                                                                                                                                                                                                                               |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [27]  | RWSC                     | lpm_int     |            | In device mode, an interrupt is generated when the device receives an LPM transaction and transmits a response indicating no errors.<br>In host mode, an interrupt is generated when the device receives an LPM transaction and transmits a response indicating no errors, or when the host core completes the preset LPM transactions.<br>Note: This bit is valid only when LPMC capable or OTG_ENABLE_LPM is 1.<br>Setting this bit to 1 clears the interrupt. |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [26]  | RO                       | ptxfemp     |            | An interrupt is generated when the periodic TX FIFO is empty or half empty.                                                                                                                                                                                                                                                                                                                                                                                      |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [25]  | RO                       | hchint      |            | In host mode, an interrupt is generated in a core channel.<br>This bit is cleared by clearing the corresponding status bit.                                                                                                                                                                                                                                                                                                                                      |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |
| [24]  | RO                       | prtint      |            | In host mode, an interrupt is generated when the status of a port of the DWC_otg core changes.<br>Note: This bit is cleared by clearing the corresponding bit in the host port control and status register.                                                                                                                                                                                                                                                      |         |         |        |        |         |         |                     |                     |        |        |       |             |                          |            |          |        |         |           |          |            |                                  |         |        |     |       |         |        |   |



|       |      |                      |                                                                                                                                                                                                                                                    |
|-------|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23]  | RWSC | resetdet             | In device mode, an interrupt is generated when the device is suspended and the system detects that the USB module is reset in power-down mode. In host mode, this interrupt is not generated.<br>Note: Setting this bit to 1 clears the interrupt. |
| [22]  | RWSC | fetsusp              | This interrupt is valid only in DMA mode. This interrupt indicates that the core stops obtaining data from IN endpoints.                                                                                                                           |
| [21]  | RWSC | incomplpincompisoout | In host mode, an interrupt is generated if there are pending transactions.<br>In device mode, an interrupt is generated when there are isochronous OUT transfers to be completed.<br>Note: Setting this bit to 1 clears the interrupt.             |
| [20]  | RWSC | incompisoin          | An interrupt is generated when there are isochronous IN transfers to be completed.<br>In scatter/gather DMA mode, this interrupt is not generated.<br>Note: Setting this bit to 1 clears the interrupt.                                            |
| [19]  | RO   | oepint               | In device mode, an interrupt is generated on an OUT endpoint. This interrupt is cleared by clearing the corresponding status bit in the DOEPINT $n$ register.                                                                                      |
| [18]  | RO   | iepint               | In device mode, an interrupt is generated on an IN endpoint. This interrupt is cleared by clearing the corresponding status bit in the DOEPINT $n$ register.                                                                                       |
| [17]  | RO   | epmis                | An interrupt is generated when endpoints mismatch. This bit is valid only during shared FIFO operations.<br>Note: Setting this bit to 1 clears the interrupt.                                                                                      |
| [16]  | RWSC | rstrdoneint          | An interrupt is caused by the restore command after hibernation.<br>Note: This bit is valid only when the hibernation function is enabled.                                                                                                         |
| [15]  | RWSC | eopf                 | Periodic frame end interrupt<br>Setting this bit to 1 clears the interrupt.                                                                                                                                                                        |
| [14]  | RWSC | isooutdrop           | Isochronous OUT packet drop interrupt<br>Note: Setting this bit to 1 clears the interrupt.                                                                                                                                                         |
| [13]  | RWSC | enumdone             | Speed enumeration completion interrupt<br>Note: Setting this bit to 1 clears the interrupt.                                                                                                                                                        |
| [12]  | RWSC | usbrst               | USB reset detection interrupt<br>Note: Setting this bit to 1 clears the interrupt.                                                                                                                                                                 |
| [11]  | RWSC | usbsusp              | USB suspend detection interrupt<br>Note: Setting this bit to 1 clears the interrupt.                                                                                                                                                               |
| [10]  | RWSC | erlysusp             | Interrupt indicating that the USB is idle for 3 ms<br>Note: Setting this bit to 1 clears the interrupt.                                                                                                                                            |
| [9:8] | -    | reserved             | Reserved                                                                                                                                                                                                                                           |



|     |      |            |                                                                                                                                                                                                                                                        |
|-----|------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | RO   | goutnakeff | An interrupt is generated when the global OUT NAK bit in the device control register is set.<br>This interrupt is cleared by clearing the global OUT NAK bit.                                                                                          |
| [6] | RO   | ginnakeff  | An interrupt is generated when the global non-periodic IN NAK is set in the device control register.                                                                                                                                                   |
| [5] | RO   | nptxfemp   | An interrupt is generated when the non-periodic TX FIFO is empty or half empty.                                                                                                                                                                        |
| [4] | RO   | rxflvl     | An interrupt is generated when there is at least one pending packet to be read by the RX FIFO.                                                                                                                                                         |
| [3] | RWSC | sof        | In host mode, an interrupt is generated when an SOF, micro-SOF, or keep-active is being transmitted.<br>In device mode, an interrupt is generated when an SOF token is received by the USB module.                                                     |
| [2] | RO   | otgint     | An interrupt is generated when an OTG even is in progress.<br>This interrupt is cleared by clearing the corresponding bit in the GOTGINT register.                                                                                                     |
| [1] | RWSC | modemis    | Mode mismatch interrupt<br>When the core works in device mode, a register in host mode needs to be accessed.<br>When the core works in host mode, a register in device mode needs to be accessed.<br>Note: Setting this bit to 1 clears the interrupt. |
| [0] | RO   | curmod     | Current operating mode<br>0: device mode<br>1: host mode                                                                                                                                                                                               |

## GINTMSK

GINTMSK is a system interrupt mask register.



| Bit   | Offset Address<br>0x0018 |                 |               |                                                                                    |            |            |           |           |             |             |                            |               | Register Name<br>GINTMSK |           |          |          |         |               |             |           |          |              |           |              | Total Reset Value<br>0x0000_0000 |              |            |          |        |          |            |          |  |  |  |  |
|-------|--------------------------|-----------------|---------------|------------------------------------------------------------------------------------|------------|------------|-----------|-----------|-------------|-------------|----------------------------|---------------|--------------------------|-----------|----------|----------|---------|---------------|-------------|-----------|----------|--------------|-----------|--------------|----------------------------------|--------------|------------|----------|--------|----------|------------|----------|--|--|--|--|
|       | 31                       | 30              | 29            | 28                                                                                 | 27         | 26         | 25        | 24        | 23          | 22          | 21                         | 20            | 19                       | 18        | 17       | 16       | 15      | 14            | 13          | 12        | 11       | 10           | 9         | 8            | 7                                | 6            | 5          | 4        | 3      | 2        | 1          | 0        |  |  |  |  |
| Name  | wkupintmsk               | sessreqintmsk   | disconnintmsk | conidstschngmsk                                                                    | lpm_intmsk | ptxfempmsk | hchintmsk | prtintmsk | resetdetmsk | fetsuspmesk | incomplpmkskincompisoutmsk | incompoimnmsk | oepintmsk                | iepintmsk | epmismsk | reserved | eopfmsk | isooutdropmsk | enumdonemsk | usbriumsk | usbupmsk | erlysuspmesk | i2cintmsk | ulpickintmsk | goutnakeffmsk                    | ginnakeffmsk | npxfempmsk | rxflvmsk | sofmsk | oigimmsk | modemismsk | reserved |  |  |  |  |
| Reset | 0                        | 0               | 0             | 0                                                                                  | 0          | 0          | 0         | 0         | 0           | 0           | 0                          | 0             | 0                        | 0         | 0        | 0        | 0       | 0             | 0           | 0         | 0        | 0            | 0         | 0            | 0                                | 0            | 0          | 0        | 0      | 0        | 0          |          |  |  |  |  |
| Bits  | Access                   | Name            |               | Description                                                                        |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [31]  | RW                       | wkupintmsk      |               | Resume/Remote wakeup detection interrupt mask<br>0: masked<br>1: not masked        |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [30]  | RW                       | sessreqintmsk   |               | Session request/new session detection interrupt mask<br>0: masked<br>1: not masked |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [29]  | RW                       | disconnintmsk   |               | Disconnect detection interrupt mask.<br>0: masked<br>1: not masked                 |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [28]  | RW                       | conidstschngmsk |               | Connector ID status change interrupt mask<br>0: masked<br>1: not masked            |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [27]  | RW                       | lpm_intmsk      |               | LPM transaction RX interrupt mask<br>0: masked<br>1: not masked                    |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [26]  | RW                       | ptxfempmsk      |               | Periodic TX FIFO empty interrupt mask<br>0: masked<br>1: not masked                |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [25]  | RW                       | hchintmsk       |               | Host channel interrupt mask<br>0: masked<br>1: not masked                          |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |
| [24]  | RW                       | prtintmsk       |               | Host port interrupt mask<br>0: masked<br>1: not masked                             |            |            |           |           |             |             |                            |               |                          |           |          |          |         |               |             |           |          |              |           |              |                                  |              |            |          |        |          |            |          |  |  |  |  |



|      |    |                                |                                                                                                                                                                                |
|------|----|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [23] | RW | resetdetmsk                    | Reset detection interrupt mask<br>0: masked<br>1: not masked                                                                                                                   |
| [22] | RW | fetsuspmask                    | Data fetch suspended interrupt mask<br>0: masked<br>1: not masked                                                                                                              |
| [21] | RW | incomplpmkincom<br>pisououtmsk | Incomplete periodic transfer interrupt mask<br>0: masked<br>1: not masked<br>Incomplete isochronous OUT transfer interrupt mask<br>0: masked<br>1: not masked                  |
| [20] | RW | incompisoimask                 | Incomplete isochronous IN transfer interrupt mask<br>0: masked<br>1: not masked<br>This bit can be enabled only when periodic endpoints are enabled in dedicated TX FIFO mode. |
| [19] | RW | oepintmsk                      | OUT endpoints interrupt mask<br>0: masked<br>1: not masked                                                                                                                     |
| [18] | RW | iepintmsk                      | IN endpoints interrupt mask<br>0: masked<br>1: not masked                                                                                                                      |
| [17] | RW | epmismsk                       | Endpoint mismatch interrupt mask<br>0: masked<br>1: not masked                                                                                                                 |
| [16] | -  | reserved                       | Reserved                                                                                                                                                                       |
| [15] | RW | eopfmsk                        | End of periodic frame interrupt mask<br>0: masked<br>1: not masked                                                                                                             |
| [14] | RW | isooutdropmsk                  | Device only isochronous OUT packet drop interrupt mask<br>0: masked<br>1: not masked                                                                                           |
| [13] | RW | enumdonemsk                    | Enumeration done interrupt mask<br>0: masked<br>1: not masked                                                                                                                  |



|      |    |               |                                                                                                                                  |
|------|----|---------------|----------------------------------------------------------------------------------------------------------------------------------|
| [12] | RW | usbrstmsk     | USB reset interrupt mask<br>0: masked<br>1: not masked                                                                           |
| [11] | RW | usbsuspmsk    | USB suspend interrupt mask<br>0: masked<br>1: not masked                                                                         |
| [10] | RW | erlysuspmsk   | Early suspend interrupt mask<br>0: masked<br>1: not masked                                                                       |
| [9]  | RW | i2cintmsk     | I <sup>2</sup> C interrupt mask<br>0: masked<br>1: not masked                                                                    |
| [8]  | RW | ulpickintmsk  | ULPI Carkit interrupt mask<br>0: masked<br>1: not masked<br>I <sup>2</sup> C Carkit interrupt mask<br>0: masked<br>1: not masked |
| [7]  | RW | goutnakeffmsk | Global OUT NAK effective interrupt mask<br>0: masked<br>1: not masked                                                            |
| [6]  | RW | ginnakeffmsk  | Global non-periodic IN NAK effective interrupt mask<br>0: masked<br>1: not masked                                                |
| [5]  | RW | nptxfempmsk   | Non-periodic TX FIFO empty interrupt mask<br>0: masked<br>1: not masked                                                          |
| [4]  | RW | rxflvlmsk     | Receive FIFO non-empty interrupt mask<br>0: masked<br>1: not masked                                                              |
| [3]  | RW | sofmsk        | Start of (micro)frame interrupt mask<br>0: masked<br>1: not masked                                                               |
| [2]  | RW | otgintmsk     | Device interrupt mask<br>0: masked<br>1: not masked                                                                              |



|     |    |            |                                                            |
|-----|----|------------|------------------------------------------------------------|
| [1] | RW | modemismsk | Mode mismatch interrupt mask<br>0: masked<br>1: not masked |
| [0] | RW | reserved   | Reserved                                                   |

## GRXSTSR

GRXSTSR is an RX status debugging read register.

|         | Offset Address<br>0x001C |                     |    |    |                                                                                                                                                                         |    |    |    |                   |    |    |    |                 |    |    |    | Register Name<br>GRXSTSR |    |    |    |                   |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |
|---------|--------------------------|---------------------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-------------------|----|----|----|-----------------|----|----|----|--------------------------|----|----|----|-------------------|----|---|---|----------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                       | 30                  | 29 | 28 | 27                                                                                                                                                                      | 26 | 25 | 24 | 23                | 22 | 21 | 20 | 19              | 18 | 17 | 16 | 15                       | 14 | 13 | 12 | 11                | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved_devicemode      |                     |    |    | fn_devicemode                                                                                                                                                           |    |    |    | pktsts_devicemode |    |    |    | dpid_devicemode |    |    |    | bcnt_devicemode          |    |    |    | chnum_device mode |    |   |   |                                  |   |   |   |   |   |   |   |
| Reset   | 0                        | 0                   | 0  | 0  | 0                                                                                                                                                                       | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0                        | 0  | 0  | 0  | 0                 | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 |   |   |   |
| Bits    | Access                   | Name                |    |    | Description                                                                                                                                                             |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |
| [31:25] | -                        | reserved_devicemode |    |    | Reserved                                                                                                                                                                |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |
| [24:21] | RO                       | fn_devicemode       |    |    | Number of frames                                                                                                                                                        |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |
| [20:17] | RO                       | pktsts_devicemode   |    |    | Data packet status<br>0001: global OUT NAK (interrupt triggered)<br>0010: IN data packet received<br>0111: channel stop (interrupt triggered)<br>Other values: reserved |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |
| [16:15] | RO                       | dpid_devicemode     |    |    | Data PID of the received packet<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA                                                                                     |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |
| [14:4]  | RO                       | bcnt_devicemode     |    |    | Byte size of the received IN data packets                                                                                                                               |    |    |    |                   |    |    |    |                 |    |    |    |                          |    |    |    |                   |    |   |   |                                  |   |   |   |   |   |   |   |



|       |    |                  |                                                                     |
|-------|----|------------------|---------------------------------------------------------------------|
| [3:0] | RO | chnum_devicemode | Number of channels from which the current data packets are received |
|-------|----|------------------|---------------------------------------------------------------------|

## GRXSTSP

GRXSTSP is an RX status read&pop register.

|         | Offset Address      |                     |    |    |                                                                                                                                                                                                                                                                                |               |    |    |    |    | Register Name     |    |    |    |    |                 |    |    |    |    | Total Reset Value |    |   |   |   |                  |   |   |   |   |   |   |
|---------|---------------------|---------------------|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----|----|----|----|-------------------|----|----|----|----|-----------------|----|----|----|----|-------------------|----|---|---|---|------------------|---|---|---|---|---|---|
|         | 0x0020              |                     |    |    |                                                                                                                                                                                                                                                                                |               |    |    |    |    | GRXSTSP           |    |    |    |    |                 |    |    |    |    | 0x0000_0000       |    |   |   |   |                  |   |   |   |   |   |   |
| Bit     | 31                  | 30                  | 29 | 28 | 27                                                                                                                                                                                                                                                                             | 26            | 25 | 24 | 23 | 22 | 21                | 20 | 19 | 18 | 17 | 16              | 15 | 14 | 13 | 12 | 11                | 10 | 9 | 8 | 7 | 6                | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved_devicemode |                     |    |    |                                                                                                                                                                                                                                                                                | fn_devicemode |    |    |    |    | pktsts_devicemode |    |    |    |    | dpid_devicemode |    |    |    |    | bcnt_devicemode   |    |   |   |   | chnum_devicemode |   |   |   |   |   |   |
| Reset   | 0                   | 0                   | 0  | 0  | 0                                                                                                                                                                                                                                                                              | 0             | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0                 | 0  | 0 | 0 | 0 | 0                | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access              | Name                |    |    | Description                                                                                                                                                                                                                                                                    |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [31:25] | -                   | reserved_devicemode |    |    | Reserved                                                                                                                                                                                                                                                                       |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [24:21] | RO                  | fn_devicemode       |    |    | Number of frames                                                                                                                                                                                                                                                               |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [20:17] | RO                  | pktsts_devicemode   |    |    | Data packet status<br>0001: global OUT NAK (interrupt triggered)<br>0010: IN data packet received<br>0111: IN transfer completion (interrupt triggered)<br>0101: data toggle error (interrupt triggered)<br>0111: channel stop (interrupt triggered)<br>Other values: reserved |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [16:15] | RO                  | dpid_devicemode     |    |    | Data PID of the received packet<br>00: DATA0<br>10: DATA1<br>01: DATA2<br>11: MDATA                                                                                                                                                                                            |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [14:4]  | RO                  | bcnt_devicemode     |    |    | Byte size of the received IN data packets                                                                                                                                                                                                                                      |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |
| [3:0]   | RO                  | chnum_devicemode    |    |    | Number of channels from which the current data packets are received                                                                                                                                                                                                            |               |    |    |    |    |                   |    |    |    |    |                 |    |    |    |    |                   |    |   |   |   |                  |   |   |   |   |   |   |



GRXFSIZ

GRXFSIZ is an RX FIFO size configuration register.

| Offset Address |          |          |    |    |                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|-----------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0024         |          |          |    |    |                             |    |    | GRXFSIZ       |    |    |    |    |    |    |    | 0x0000_0211       |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |                             |    |    |               |    |    |    |    |    |    |    |                   | rxfdep |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0      | 0  | 0  | 0  | 0  | 1  | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |   |
| Bits           | Access   | Name     |    |    | Description                 |    |    |               |    |    |    |    |    |    |    |                   |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RO       | reserved |    |    | Reserved                    |    |    |               |    |    |    |    |    |    |    |                   |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | R/RW     | rxfdep   |    |    | RX FIFO depth<br>16–32, 768 |    |    |               |    |    |    |    |    |    |    |                   |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

GNPTXFSIZ

GNPTXFSIZ is a non-periodic TX FIFO size configuration register.

| Offset Address |             |                |    |    |                                                    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-------------|----------------|----|----|----------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0028         |             |                |    |    |                                                    |    |    | GNPTXFSIZ     |    |    |    |    |    |    |    | 0x0100_0211       |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31          | 30             | 29 | 28 | 27                                                 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | ineptxf0dep |                |    |    |                                                    |    |    |               |    |    |    |    |    |    |    |                   | ineptxf0staddr |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0           | 0              | 0  | 0  | 0                                                  | 0  | 1  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0              | 0  | 0  | 0  | 1  | 0  | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |   |   |
| Bits           | Access      | Name           |    |    | Description                                        |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW          | ineptxf0dep    |    |    | Depth of IN endpoint TX FIFO 0<br>16–32, 768       |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW          | ineptxf0staddr |    |    | Start address for the TX RAM of IN endpoint FIFO 0 |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

GNPTXSTS

GNPTXSTS is a non-periodic TX FIFO and non-periodic TX request query register.



| Offset Address |          |               |    |    |                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    | Register Name |    |              |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |  |               |
|----------------|----------|---------------|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|--------------|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|--|---------------|
| 0x002C         |          |               |    |    |                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    | GNPTXSTS      |    |              |    |    |    |    |   | 0x0008_0100       |   |   |   |   |   |   |   |   |  |               |
| Bit            | 31       | 30            | 29 | 28 | 27                                                                                                                                                                                                                                                                                               | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15 | 14           | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |               |
| Name           | reserved | nptxqtop      |    |    |                                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |    |    |    |               |    | nptxspcavail |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  | nptxfspcavail |
| Reset          | 0        | 0             | 0  | 0  | 0                                                                                                                                                                                                                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0             | 0  | 0            | 0  | 0  | 0  | 0  | 1 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |  |               |
| Bits           | Access   | Name          |    |    | Description                                                                                                                                                                                                                                                                                      |    |    |    |    |    |    |    |    |    |    |               |    |              |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |               |
| [31]           | -        | reserved      |    |    | Reserved                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |               |    |              |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |               |
| [30:24]        | RO       | nptxqtop      |    |    | Non-periodic TX request queue top<br>Bit[30:27]: number of channels or endpoints<br>bit[26:25]:<br>00: IN/OUT token<br>01: zero-length TX packet (device IN/host OUT)<br>10: PING/CSPLIT token<br>11: channel stop command<br>Bit[24]: stop (last attempt on the selected channel or endpoint)   |    |    |    |    |    |    |    |    |    |    |               |    |              |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |               |
| [23:16]        | RO       | nptxspcavail  |    |    | Available space for the non-periodic TX request queue<br>0x0: The non-periodic TX request queue is full.<br>0x1: One address is available.<br>0x2: Two addresses are available.<br>0xn: $n$ addresses ( $0 \leq n \leq 8$ ) are available.<br>Other values: reserved                             |    |    |    |    |    |    |    |    |    |    |               |    |              |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |               |
| [15:0]         | RO       | nptxfspcavail |    |    | Total available space for the non-periodic TX request queue<br>0x0: The non-periodic TX FIFO is Full.<br>0x1: One word is available.<br>0x2: Two words are available.<br>0xn: $n$ words ( $0 \leq n \leq 32768$ ) are available.<br>0x8000: 32768 words are available.<br>Other values: reserved |    |    |    |    |    |    |    |    |    |    |               |    |              |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |  |               |

## GI2CCTL

GI2CCTL is an I<sup>2</sup>C access register.



|         | Offset Address |             |          |           |           |                                                                                                                                              |     |       |      |    |    |    |         |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value |   |   |   |   |   |   |   |
|---------|----------------|-------------|----------|-----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|------|----|----|----|---------|----|----|----|---------------|----|----|----|----|----|---|---|-------------------|---|---|---|---|---|---|---|
|         | 0x0030         |             |          |           |           |                                                                                                                                              |     |       |      |    |    |    |         |    |    |    | GI2CCTL       |    |    |    |    |    |   |   | 0x0000_0000       |   |   |   |   |   |   |   |
| Bit     | 31             | 30          | 29       | 28        | 27        | 26                                                                                                                                           | 25  | 24    | 23   | 22 | 21 | 20 | 19      | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | bsydone        | rw          | reserved | i2cdatse0 | i2cdevadr | i2csuspcctl                                                                                                                                  | ack | i2cen | addr |    |    |    | regaddr |    |    |    | rwdata        |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| Reset   | 0              | 0           | 0        | 0         | 0         | 0                                                                                                                                            | 0   | 0     | 0    | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access         | Name        |          |           |           | Description                                                                                                                                  |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [31]    | RWSC           | bsydone     |          |           |           | $I^2C$ busy/done<br>0: $I^2C$ done<br>1: $I^2C$ busy                                                                                         |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [30]    | RW             | rw          |          |           |           | Read/Write indicator<br>0: write<br>1: read                                                                                                  |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [29]    | RW             | reserved    |          |           |           | Reserved                                                                                                                                     |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [28]    | RW             | i2cdatse0   |          |           |           | $I^2C$ mode of the FS interface<br>0: VP_VM USB mode<br>1: DAT_SE0 USB mode                                                                  |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [27:26] | RW             | i2cdevadr   |          |           |           | $I^2C$ device address<br>00: 7'h2C<br>01: 7'h2D<br>10: 7'h2E<br>11: 7'h2F                                                                    |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [25]    | RW             | i2csuspcctl |          |           |           | $I^2C$ suspend control<br>0: utmi_suspend_n is used.<br>1: The suspend bit in the PHY register is edited by using the $I^2C$ write function. |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [24]    | RO             | ack         |          |           |           | $I^2C$ ACK<br>0: NAK<br>1: ACK                                                                                                               |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [23]    | RW             | i2cen       |          |           |           | $I^2C$ transaction enable<br>0: disabled<br>1: enabled                                                                                       |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [22:16] | RW             | addr        |          |           |           | $I^2C$ slave address                                                                                                                         |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [15:8]  | RW             | regaddr     |          |           |           | $I^2C$ register address                                                                                                                      |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [7:0]   | RW             | rwdata      |          |           |           | $I^2C$ read/write data                                                                                                                       |     |       |      |    |    |    |         |    |    |    |               |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |



## GPVNDCTL

GPVNDCTL is a PHY vendor control register.

| Bit     | Offset Address<br>0x0034 |                 |         |                                                                                                                                        |          |       |         |                 |    |    |    |    |    |    |    |         | Register Name<br>GPVNDCTL |    |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |
|---------|--------------------------|-----------------|---------|----------------------------------------------------------------------------------------------------------------------------------------|----------|-------|---------|-----------------|----|----|----|----|----|----|----|---------|---------------------------|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|
|         | 31                       | 30              | 29      | 28                                                                                                                                     | 27       | 26    | 25      | 24              | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      | 15                        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 | vstsdone        | vstsbsy | newreq                                                                                                                                 | reserved | regwr | regaddr | vctrlextregaddr |    |    |    |    |    |    |    | regdata |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| Reset   | 0                        | 0               | 0       | 0                                                                                                                                      | 0        | 0     | 0       | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0                         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access                   | Name            |         | Description                                                                                                                            |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [31:28] | -                        | reserved        |         | Reserved                                                                                                                               |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [27]    | RWSC                     | vstsdone        |         | Vendor control access (done)<br>0: The new register request is set.<br>1: Vendor control access ends.                                  |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [26]    | RO                       | vstsbsy         |         | Vendor control access (busy)<br>0: Vendor control access ends.<br>1: Vendor control access is in progress.                             |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [25]    | RWSC                     | newreq          |         | New vendor control access<br>0: no access request<br>1: new vendor control access request                                              |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [24:23] | -                        | reserved        |         | Reserved                                                                                                                               |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [22]    | RW                       | regwr           |         | Register read/write<br>0: read<br>1: write                                                                                             |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [21:16] | RW                       | regaddr         |         | Register access address                                                                                                                |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [15:8]  | RW                       | vctrlextregaddr |         | Address for the UTMI+vendor control register<br>Bit[15:12]: 4-bit parallel output bus addressing<br>Bit[11:8]: from utmi_vcontrol[3:0] |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [7:0]   | RW                       | regdata         |         | Register data<br>This bit is valid after the Vstatus done bit is set.                                                                  |          |       |         |                 |    |    |    |    |    |    |    |         |                           |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |



# GGPIO

GGPIO is a GPIO register.

## GUID

GUID is a user ID register.

## GSNPSID

GSNPSID is a Synopsys ID query register.

| Offset Address |            |            |    |    |                                |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|------------|------------|----|----|--------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0040         |            |            |    |    |                                |    |    | GSNPSID       |    |    |    |    |    |    |    | 0x4F54_300A       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31         | 30         | 29 | 28 | 27                             | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | synopsysid |            |    |    |                                |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0          | 1          | 0  | 0  | 1                              | 1  | 1  | 1             | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0                 | 0  | 0  | 1  | 1  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |   |
| Bits           | Access     | Name       |    |    | Description                    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RW         | synopsysid |    |    | ID of the current DWC_otg core |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



GHWCFG1

**GHWCFG1** is user hardware configuration register 1.

GHWCFG2

GHWCFG2 is user hardware configuration register 2.



| Offset Address<br>0x0048 |                   |                   |    |                                                                                              |    |           |            |          |                 |               |              | Register Name<br>GHWCFG2 |    |    |    |           |    |    |    |           |            |         |         | Total Reset Value<br>0x2284_C850 |   |   |   |   |   |   |   |   |  |  |  |
|--------------------------|-------------------|-------------------|----|----------------------------------------------------------------------------------------------|----|-----------|------------|----------|-----------------|---------------|--------------|--------------------------|----|----|----|-----------|----|----|----|-----------|------------|---------|---------|----------------------------------|---|---|---|---|---|---|---|---|--|--|--|
| Bit                      | 31                | 30                | 29 | 28                                                                                           | 27 | 26        | 25         | 24       | 23              | 22            | 21           | 20                       | 19 | 18 | 17 | 16        | 15 | 14 | 13 | 12        | 11         | 10      | 9       | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name                     | otg_enable_ic_usb | tknqdepth         |    |                                                                                              |    | ptxqdepth | nptxqdepth | reserved | multiprocintrpt | dynfifosizing | periosupport | numhstchnl               |    |    |    | numdeveps |    |    |    | fphystype | hsphystype | singpnt | otgarch | otgmode                          |   |   |   |   |   |   |   |   |  |  |  |
| Reset                    | 0                 | 0                 | 1  | 0                                                                                            | 0  | 0         | 1          | 0        | 1               | 0             | 0            | 0                        | 0  | 1  | 0  | 0         | 1  | 1  | 0  | 0         | 1          | 0       | 0       | 0                                | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |
| Bits                     | Access            | Name              |    | Description                                                                                  |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [31]                     | RO                | otg_enable_ic_usb |    | IC_USB select enable<br>0: disabled<br>1: enabled                                            |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [30:26]                  | RO                | tknqdepth         |    | Depth of the IN token sequence learning queue in device mode<br>The value range is 0–30.     |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [25:24]                  | RO                | ptxqdepth         |    | Depth of the periodic request queue in host mode<br>00: 2<br>01: 4<br>10: 8<br>11: 16        |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [23:22]                  | RO                | nptxqdepth        |    | Depth of the non-periodic request queue<br>00: 2<br>01: 4<br>10: 8<br>Other values: reserved |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [21]                     |                   | reserved          |    | Reserved                                                                                     |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [20]                     | RW                | multiprocintrpt   |    | Multi-processor interrupt enable<br>0: disabled<br>1: enabled                                |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [19]                     | RO                | dynfifosizing     |    | FIFO size dynamic change enable<br>0: disabled<br>1: enabled                                 |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |
| [18]                     | RO                | periosupport      |    | Periodic OUT channel support in host mode<br>0: not supported<br>1: supported                |    |           |            |          |                 |               |              |                          |    |    |    |           |    |    |    |           |            |         |         |                                  |   |   |   |   |   |   |   |   |  |  |  |



|         |    |            |                                                                                                                                                                                                                                                                                           |
|---------|----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17:14] | RO | numhstchnl | Number of host channels<br>0–15: The value 0 indicates one channel, and the value 15 indicates 16 channels.                                                                                                                                                                               |
| [13:10] | RO | numdeveps  | Number of device endpoints (excluding endpoint 0)<br>The value range is 0–15.                                                                                                                                                                                                             |
| [9:8]   | RO | fsphytype  | Type of the full-speed PHY interface<br>00: The full-speed interface is not supported.<br>01: The full-speed interface is supported.<br>10: FS pins share with UTMI+ pins.<br>11: FS pins share with ULPI pins.                                                                           |
| [7:6]   | RO | hsphytype  | Type of the high-speed PHY interface<br>00: high-speed interface not supported<br>01: UTMI+<br>10: ULPI<br>11: UTMI+ and ULPI                                                                                                                                                             |
| [5]     | RO | singpnt    | Point-to-point<br>0: multi-point application (hub and split supported)<br>1: single-point application (hub and split not supported)                                                                                                                                                       |
| [4:3]   | RO | otgarch    | Device architecture<br>00: slave-only<br>01: external DMA<br>10: internal DMA<br>Other values: reserved                                                                                                                                                                                   |
| [2:0]   | RO | otgmode    | Operating mode<br>000: HNP- and SRP-capable OTG (host & device)<br>001: SRP-Capable OTG (host & device)<br>010: Non-HNP and Non-SRP Capable OTG (host & device)<br>011: SRP-capable device<br>100: Non-OTG device<br>101: SRP-capable host<br>110: Non-OTG host<br>Other values: reserved |

## GHWCFG3

GHWCFG3 is user hardware configuration register 3.



|         | Offset Address<br>0x004C |             |                                                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>GHWCFG3 |    |    |    |    |    |    |    |   |   | Total Reset Value<br>0x0501_54E8 |   |   |   |   |   |   |   |  |  |
|---------|--------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|--|--|
| Bit     | 31                       | 30          | 29                                                                                                                                                | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| Name    | dffifodepth              |             |                                                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| Reset   | 0                        | 0           | 0                                                                                                                                                 | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0 | 0 | 1                                | 1 | 1 | 0 | 1 | 0 | 0 | 0 |  |  |
| Bits    | Access                   | Name        | Description                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [31:16] | RO                       | dffifodepth | DFIFO depth<br>32–32, 768                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [15]    | RO                       | lpemode     | LPM mode select                                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [14]    | RO                       | bcsupport   | Whether the HS device controller supports the battery charger<br>0: not supported<br>1: supported                                                 |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [13]    | RO                       | hsicmode    | HSIC mode select<br>0: The HSIC-capable shares with the UTMI PHY interface<br>1: The HSIC mode is not selected.                                   |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [12]    | RO                       | adpsupport  | Whether the device controller has an ADP logic<br>0: no<br>1: yes                                                                                 |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [11]    | RO                       | rsttype     | Reset mode of clock always blocks<br>0: asynchronous reset<br>1: synchronous reset                                                                |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [10]    | RO                       | optfeature  | Feature removal<br>Features include the user ID register, GPIO interface ports, and SOF toggle and counter ports.<br>0: not removed<br>1: removed |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [9]     | RO                       | vndctlupt   | Vendor control interface support<br>0: not supported<br>1: supported                                                                              |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |
| [8]     | RO                       | i2cintsel   | I <sup>2</sup> C interface select<br>0: not selected<br>1: selected                                                                               |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |  |



|       |    |               |                                                                                                                                                       |
|-------|----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]   | RO | otgen         | Device function enable<br>0: disabled<br>1: enabled                                                                                                   |
| [6:4] | RO | pktsizewidth  | Data packet width<br>000: 4 bits<br>001: 5 bits<br>010: 6 bits<br>011: 7 bits<br>100: 8 bits<br>101: 9 bits<br>110: 10 bits<br>Other values: reserved |
| [3:0] | RO | xfersizewidth | Transfer width<br>0000: 11 bits<br>0001: 12 bits<br>1000: 19 bits<br>Other values: reserved                                                           |

## GHWCFG4

GHWCFG4 is user hardware configuration register 4.

| Offset Address |         |           |           |    |    |    |                                                                               |             |            |            |               | Register Name |           |    |              |          |    |    |    |    |    |                    |             | Total Reset Value |              |                |   |   |   |   |   |   |  |  |  |
|----------------|---------|-----------|-----------|----|----|----|-------------------------------------------------------------------------------|-------------|------------|------------|---------------|---------------|-----------|----|--------------|----------|----|----|----|----|----|--------------------|-------------|-------------------|--------------|----------------|---|---|---|---|---|---|--|--|--|
| 0x0050         |         |           |           |    |    |    |                                                                               |             |            |            |               | GHWCFG4       |           |    |              |          |    |    |    |    |    |                    |             | 0x4600_8020       |              |                |   |   |   |   |   |   |  |  |  |
| Bit            | 31      | 30        | 29        | 28 | 27 | 26 | 25                                                                            | 24          | 23         | 22         | 21            | 20            | 19        | 18 | 17           | 16       | 15 | 14 | 13 | 12 | 11 | 10                 | 9           | 8                 | 7            | 6              | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | descdma | descdmaen | ineps     |    |    |    | dedfifomode                                                                   | sessendfltr | bvalidfltr | avalidfltr | vbusvalidfltr | iddgfltr      | numctleps |    | phydatawidth | reserved |    |    |    |    |    | extndedhibernation | hibernation | ahbfreq           | partialpwrdn | numdevperioeps |   |   |   |   |   |   |  |  |  |
| Reset          | 0       | 1         | 0         | 0  | 0  | 1  | 1                                                                             | 0           | 0          | 0          | 0             | 0             | 0         | 0  | 0            | 1        | 0  | 0  | 0  | 0  | 0  | 0                  | 0           | 0                 | 0            | 1              | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |
| Bits           | Access  |           | Name      |    |    |    | Description                                                                   |             |            |            |               |               |           |    |              |          |    |    |    |    |    |                    |             |                   |              |                |   |   |   |   |   |   |  |  |  |
| [31]           | RO      |           | descdma   |    |    |    | Scatter/Gather DMA<br>0: no dynamic configuration<br>1: dynamic configuration |             |            |            |               |               |           |    |              |          |    |    |    |    |    |                    |             |                   |              |                |   |   |   |   |   |   |  |  |  |
| [30]           | RO      |           | descdmaen |    |    |    | Pad slew rate<br>0: fast<br>1: slow                                           |             |            |            |               |               |           |    |              |          |    |    |    |    |    |                    |             |                   |              |                |   |   |   |   |   |   |  |  |  |



|         |    |                    |                                                                                                                                                               |
|---------|----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [29:26] | RO | ineps              | Number of IN endpoints in device mode<br>0: 1<br>1: 2<br>...<br>15: 16                                                                                        |
| [25]    | RO | dedfifomode        | Dedicated TX FIFO enable for device IN endpoints<br>0: disabled<br>1: enabled                                                                                 |
| [24]    | RO | sessendfltr        | session_end filter enable<br>0: disabled<br>1: enabled                                                                                                        |
| [23]    | RO | bvalidfltr         | b_valid filter enable<br>0: disabled<br>1: enabled                                                                                                            |
| [22]    | RO | avalidfltr         | a_valid filter enable<br>0: disabled<br>1: enabled                                                                                                            |
| [21]    | RO | vbusvalidfltr      | Vbus valid filter enable<br>0: disabled<br>1: enabled                                                                                                         |
| [20]    | RO | iddgfltr           | IDDIG filter enable<br>0: disabled<br>1: enabled                                                                                                              |
| [19:16] | RO | numctleps          | Number of controlled endpoints excluding endpoint 0 in device mode<br>The value range is 0–15.                                                                |
| [15:14] | RO | phydatawidth       | Data width of the UTMI+ PHY/ULPI-to-internal UTMI+ wrapper<br>00: 8 bits<br>01: 16 bits<br>10: 8/16 bits (configurable by software)<br>Other values: reserved |
| [13:8]  | RO | reserved           | Reserved                                                                                                                                                      |
| [7]     | RO | extndedhibernation | Extended hibernation enable<br>0: disabled<br>1: enabled                                                                                                      |
| [6]     | RO | hibernation        | Hibernation enable<br>0: disabled<br>1: enabled                                                                                                               |



|       |    |                |                                                                            |
|-------|----|----------------|----------------------------------------------------------------------------|
| [5]   | RO | ahbfreq        | Whether the minimum AHB frequency is lower than 60 MHz<br>0: no<br>1: yes  |
| [4]   | RO | partialpwrdsn  | Partial power-down enable<br>0: disabled<br>1: enabled                     |
| [3:0] | RO | numdevperioeps | Number of periodic IN endpoints in device mode<br>The value range is 0–15. |

## GLPMCFG

GLPMCFG is an LPM configuration register.

| Bit   | Offset Address 0x0054 |            |           |        |                  |                                                                                                                                                                                                  |               |               |           |       |          |            |          |             |      |         | Register Name GLPMCFG |    |    |    |    |    |   |   | Total Reset Value 0x0000_0000 |   |   |   |   |   |   |   |
|-------|-----------------------|------------|-----------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------|-----------|-------|----------|------------|----------|-------------|------|---------|-----------------------|----|----|----|----|----|---|---|-------------------------------|---|---|---|---|---|---|---|
|       | 31                    | 30         | 29        | 28     | 27               | 26                                                                                                                                                                                               | 25            | 24            | 23        | 22    | 21       | 20         | 19       | 18          | 17   | 16      | 15                    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | invselhsic            | reserved   | rstrslpst | enbesl | lpm_retrycnt_sts | sndlpn                                                                                                                                                                                           | lpm_retry_cnt | lpm_chnl_indx | lresumeok | slpst | core1res | hird_thres | enblslpm | bremotewake | hird | applres | lpmcap                |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| Reset | 0                     | 0          | 0         | 0      | 0                | 0                                                                                                                                                                                                | 0             | 0             | 0         | 0     | 0        | 0          | 0        | 0           | 0    | 0       | 0                     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                             | 0 | 0 | 0 | 0 |   |   |   |
| Bits  | Access                | Name       |           |        |                  | Description                                                                                                                                                                                      |               |               |           |       |          |            |          |             |      |         |                       |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [31]  | RW                    | invselhsic |           |        |                  | HSIC enable (by using HSIC-invert)<br>If if_sel_hsic is 1:<br>InvSelHsic = 1: disabled<br>InvSelHsic = 0: enabled<br>If if_sel_hsic is 0:<br>InvSelHsic = 1: enabled<br>InvSelHsic = 0: disabled |               |               |           |       |          |            |          |             |      |         |                       |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [30]  | -                     | reserved   |           |        |                  | Reserved                                                                                                                                                                                         |               |               |           |       |          |            |          |             |      |         |                       |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [29]  | RW                    | rstrslpst  |           |        |                  | Restore SlpSts<br>0: The core enters the shallow sleep mode.<br>1: The core enters the deep sleep mode.                                                                                          |               |               |           |       |          |            |          |             |      |         |                       |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |
| [28]  | RW                    | enbesl     |           |        |                  | Best effort service latency (BESL) enable<br>0: disabled<br>1: enabled                                                                                                                           |               |               |           |       |          |            |          |             |      |         |                       |    |    |    |    |    |   |   |                               |   |   |   |   |   |   |   |



|         |      |                  |                                                                                                                                                                                                                                                                                                                          |
|---------|------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [27:25] | RO   | lpm_retrycnt_sts | LPM retry count<br>This field is used to count the remaining retries.                                                                                                                                                                                                                                                    |
| [24]    | RWSC | sndlpm           | LPM transaction TX                                                                                                                                                                                                                                                                                                       |
| [23:21] | RW   | lpm_retry_cnt    | LPM retry count statistics<br>When a device provides error information, this field shows the extra LPM retries of the host before the device validity signal arrives.                                                                                                                                                    |
| [20:17] | RW   | lpm_chnl_indx    | LPM channel index<br>The number of LPM transaction channels is provided. The core automatically calculates the device address and number of endpoints based on the LPM channel index.                                                                                                                                    |
| [16]    | RO   | l1resumeok       | Resume from the sleep state<br>0: resumed<br>1: not resumed                                                                                                                                                                                                                                                              |
| [15]    | RO   | slpst            | Port sleep state<br>0: resumed<br>1: sleep                                                                                                                                                                                                                                                                               |
| [14:13] | RO   | corel1res        | LPM response<br>In device mode, this field reflects the response to the LPM transaction.<br>In host mode, this field indicates the handshake response from the device during LPM transaction.<br>11: ACK<br>10: NYET<br>01: STALL<br>00: ERROR (no handshake response)                                                   |
| [12:8]  | RW   | hird_thres       | BESL or HIRD threshold                                                                                                                                                                                                                                                                                                   |
| [7]     | RW   | enblslpm         | utmi_sleep_n enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                         |
| [6]     | RW   | bremotewake      | Remote wakeup enable<br>In host mode, the enable signal is transmitted from the wIndex field of the LPM transaction.<br>In device mode (read-only), when the ACK, NYET, or STALL response is transmitted to the LPM transaction, this bit is updated together with the received LPM token, bRemoteWake, and bmAttribute. |



|       |         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
|-------|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|---|---------|-----|----|---------|-----|----|---------|-----|----|---------|-----|----|---------|-----|----|---------|------|----|---------|------|----|---------|------|
| [5:2] | RW      | hird     | <p>When EnBESL is 0:<br/>Host-initiated resume period.<br/>In host mode, this field is assigned by the LPM transaction.<br/>In device mode, this field is updated by LPM token HIRD bmAttribute.</p> <p>S1. No HIRD[3:0] THIRD (μs)</p> <table><tbody><tr><td>1</td><td>4'b0000</td><td>50</td></tr><tr><td>2</td><td>4'b0001</td><td>125</td></tr><tr><td>3</td><td>4'b0010</td><td>200</td></tr><tr><td>4</td><td>4'b0011</td><td>275</td></tr><tr><td>5</td><td>4'b0100</td><td>350</td></tr><tr><td>6</td><td>4'b0101</td><td>425</td></tr><tr><td>7</td><td>4'b0110</td><td>500</td></tr><tr><td>8</td><td>4'b0111</td><td>575</td></tr><tr><td>9</td><td>4'b1000</td><td>650</td></tr><tr><td>10</td><td>4'b1001</td><td>725</td></tr><tr><td>11</td><td>4'b1010</td><td>800</td></tr><tr><td>12</td><td>4'b1011</td><td>875</td></tr><tr><td>13</td><td>4'b1100</td><td>950</td></tr><tr><td>14</td><td>4'b1101</td><td>1025</td></tr><tr><td>15</td><td>4'b1110</td><td>1100</td></tr><tr><td>16</td><td>4'b1111</td><td>1175</td></tr></tbody></table> <p>When EnBESL is 1:<br/>BESL<br/>In host mode, the BESL value is transmitted to the LPM transaction<br/>In device mode, this field is updated by LPM token BESL bmAttribute.</p> | 1 | 4'b0000 | 50 | 2 | 4'b0001 | 125 | 3 | 4'b0010 | 200 | 4 | 4'b0011 | 275 | 5 | 4'b0100 | 350 | 6 | 4'b0101 | 425 | 7 | 4'b0110 | 500 | 8 | 4'b0111 | 575 | 9 | 4'b1000 | 650 | 10 | 4'b1001 | 725 | 11 | 4'b1010 | 800 | 12 | 4'b1011 | 875 | 13 | 4'b1100 | 950 | 14 | 4'b1101 | 1025 | 15 | 4'b1110 | 1100 | 16 | 4'b1111 | 1175 |
| 1     | 4'b0000 | 50       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 2     | 4'b0001 | 125      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 3     | 4'b0010 | 200      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 4     | 4'b0011 | 275      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 5     | 4'b0100 | 350      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 6     | 4'b0101 | 425      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 7     | 4'b0110 | 500      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 8     | 4'b0111 | 575      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 9     | 4'b1000 | 650      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 10    | 4'b1001 | 725      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 11    | 4'b1010 | 800      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 12    | 4'b1011 | 875      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 13    | 4'b1100 | 950      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 14    | 4'b1101 | 1025     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 15    | 4'b1110 | 1100     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| 16    | 4'b1111 | 1175     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| [1]   | RW      | appl1res | LPM response<br>0: NYET<br>1: ACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |
| [0]   | RW      | lpmcap   | LPM enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |         |    |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |   |         |     |    |         |     |    |         |     |    |         |     |    |         |     |    |         |      |    |         |      |    |         |      |

## GPWRDN

GPWRDN is a power-down register.



| Offset Address<br>0x0058 |          |               |    |                                                                                                                 |    |    |        |          |       |           |    | Register Name<br>GPWRDN |               |            |              |           |          |    |    |    |    |    |   | Total Reset Value<br>0x1320_0010 |            |              |           |            |          |         |           |   |  |  |  |
|--------------------------|----------|---------------|----|-----------------------------------------------------------------------------------------------------------------|----|----|--------|----------|-------|-----------|----|-------------------------|---------------|------------|--------------|-----------|----------|----|----|----|----|----|---|----------------------------------|------------|--------------|-----------|------------|----------|---------|-----------|---|--|--|--|
| Bit                      | 31       | 30            | 29 | 28                                                                                                              | 27 | 26 | 25     | 24       | 23    | 22        | 21 | 20                      | 19            | 18         | 17           | 16        | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7          | 6            | 5         | 4          | 3        | 2       | 1         | 0 |  |  |  |
| Name                     | reserved | multvalidbc   |    |                                                                                                                 |    |    | adpint | bsessvld | iddig | linestate |    |                         | stschngintmsk | stschngint | srpdetectmsk | srpdetect | reserved |    |    |    |    |    |   |                                  | disablebus | pwrndnswitch | pwrdrst_n | pwrndnclmp | reserved | pmuactv | pmuintsel |   |  |  |  |
| Reset                    | 0        | 0             | 0  | 1                                                                                                               | 0  | 0  | 1      | 1        | 0     | 0         | 0  | 1                       | 0             | 0          | 0            | 0         | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0          | 1            | 0         | 0          | 0        | 0       |           |   |  |  |  |
| Bits                     | Access   | Name          |    | Description                                                                                                     |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [31:29]                  | -        | reserved      |    | Reserved                                                                                                        |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [28:24]                  | RO       | multvalidbc   |    | BC ACA input<br>Bit 28: rid_float<br>Bit 27: rid_gnd<br>Bit 26: rid_a<br>Bit 25: rid_b<br>Bit 24: rid_c         |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [23]                     | RWSC     | adpint        |    | An interrupt is generated when the ADP is in progress<br>Setting this bit to 1 clears the interrupt.            |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [22]                     | RO       | bsessvld      |    | B session validity<br>0: B-Valid = 0<br>1: B-valid = 1                                                          |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [21]                     | RO       | iddig         |    | IDDIG signal status indicator<br>Current operating mode<br>0: host mode<br>1: device mode                       |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [20:19]                  | RO       | linestate     |    | Current line state indicator<br>00: DM = 0, DP = 0<br>01: DM = 0, DP = 1<br>10: DM = 1, DP = 0<br>11: undefined |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |
| [18]                     | RW       | stschngintmsk |    | StsChng interrupt mask<br>0: masked<br>1: not masked                                                            |    |    |        |          |       |           |    |                         |               |            |              |           |          |    |    |    |    |    |   |                                  |            |              |           |            |          |         |           |   |  |  |  |



|        |      |              |                                                                                                                                                                                                                                           |
|--------|------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]   | RWSC | stschgint    | StsChng interrupt<br>The bit indicates whether the status of the IDDIG or BSessVld signal changes.<br>0: not changed<br>1: changed                                                                                                        |
| [16]   | RW   | srpdetectmsk | SRP detection interrupt mask                                                                                                                                                                                                              |
| [15]   | RWSC | srpdetect    | SRP detection<br>0: not detected<br>1: detected                                                                                                                                                                                           |
| [14:7] | -    | reserved     | Reserved                                                                                                                                                                                                                                  |
| [6]    | RW   | disablevbus  | Vbus disable<br>In host mode:<br>0: PrtPwr is not 0.<br>1: PrtPwr is 0.<br>In device mode:<br>0: The level of the bvalid signal is high.<br>1: The level of the bvalid signal is low.<br>This bit is valid only when GPWRDN.PMUActv is 1. |
| [5]    | RW   | pwrdnswtch   | Power-down switch<br>0: on<br>1: off                                                                                                                                                                                                      |
| [4]    | RW   | pwrdnrst_n   | Power-down reset<br>0: reset<br>1: not reset                                                                                                                                                                                              |
| [3]    | RW   | pwrnclmp     | Power-down beat enable<br>0: disabled<br>1: enabled                                                                                                                                                                                       |
| [2]    | -    | reserved     | Reserved                                                                                                                                                                                                                                  |
| [1]    | RW   | pmuactv      | PMU enable<br>0: disabled<br>1: enabled                                                                                                                                                                                                   |
| [0]    | RW   | pmuintsel    | PMU interrupt select<br>0: internal DWC_otg_core interrupt<br>1: external DWC_otg_core interrupt                                                                                                                                          |

## GDFIFO CFG

GDFIFO CFG is a DFIFO software configuration register.



| Offset Address |                                                                       |                |  |  |  |  |  |  |  |  |  |  |  |  |  | Register Name |                                             |  |  |  |  |  |             | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|---------------|---------------------------------------------|--|--|--|--|--|-------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit            | 0x005C                                                                |                |  |  |  |  |  |  |  |  |  |  |  |  |  | GDFIFO CFG    |                                             |  |  |  |  |  | 0x0501_0511 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | epinfobaseaddr                                                        |                |  |  |  |  |  |  |  |  |  |  |  |  |  | gdfifocfg     |                                             |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 1 0 1 0 0 0 1 0 0 0 1 |                |  |  |  |  |  |  |  |  |  |  |  |  |  |               |                                             |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits           | Access                                                                | Name           |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Description                                 |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:16]        | RW                                                                    | epinfobaseaddr |  |  |  |  |  |  |  |  |  |  |  |  |  |               | Start address for the EP info controller    |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [15:0]         | RW                                                                    | gdfifocfg      |  |  |  |  |  |  |  |  |  |  |  |  |  |               | DFIFO size, which is dynamically configured |  |  |  |  |  |             |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |

## GADPCTL

GADPCTL is an ADP timer control and status register.

| Offset Address |                                                                                       |              |            |              |             |           |           |             |       |        |        |        |      |  |  | Register Name |                                                                                                                           |  |  |  |  |  |             | Total Reset Value |  |  |  |       |           |                                                                                       |  |
|----------------|---------------------------------------------------------------------------------------|--------------|------------|--------------|-------------|-----------|-----------|-------------|-------|--------|--------|--------|------|--|--|---------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|-------------|-------------------|--|--|--|-------|-----------|---------------------------------------------------------------------------------------|--|
| Bit            | 0x0060                                                                                |              |            |              |             |           |           |             |       |        |        |        |      |  |  | GADPCTL       |                                                                                                                           |  |  |  |  |  | 0x0000_0000 |                   |  |  |  |       |           |                                                                                       |  |
| Name           | reserved                                                                              | ar           | adptoutmsk | adpsnsintmsk | adpprintmsk | adpoutint | adpsnsint | adpprintint | adpen | adptes | enasus | enaprb | rtim |  |  |               |                                                                                                                           |  |  |  |  |  |             |                   |  |  |  | prper | pribdelta | prbdschg                                                                              |  |
| Reset          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |              |            |              |             |           |           |             |       |        |        |        |      |  |  |               |                                                                                                                           |  |  |  |  |  |             |                   |  |  |  |       |           | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |  |
| Bits           | Access                                                                                | Name         |            |              |             |           |           |             |       |        |        |        |      |  |  |               | Description                                                                                                               |  |  |  |  |  |             |                   |  |  |  |       |           |                                                                                       |  |
| [31:29]        | RW                                                                                    | reserved     |            |              |             |           |           |             |       |        |        |        |      |  |  |               | Reserved                                                                                                                  |  |  |  |  |  |             |                   |  |  |  |       |           |                                                                                       |  |
| [28:27]        | RW                                                                                    | ar           |            |              |             |           |           |             |       |        |        |        |      |  |  |               | Access request<br>00: read/write<br>01: read-only<br>10: write-only<br>11: reserved                                       |  |  |  |  |  |             |                   |  |  |  |       |           |                                                                                       |  |
| [26]           | RW                                                                                    | adptoutmsk   |            |              |             |           |           |             |       |        |        |        |      |  |  |               | ADP timeout interrupt mask<br>0: masked<br>1: not masked<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1. |  |  |  |  |  |             |                   |  |  |  |       |           |                                                                                       |  |
| [25]           | RW                                                                                    | adpsnsintmsk |            |              |             |           |           |             |       |        |        |        |      |  |  |               | ADP sense interrupt mask<br>0: masked<br>1: not masked<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.   |  |  |  |  |  |             |                   |  |  |  |       |           |                                                                                       |  |



|        |     |              |                                                                                                                                                                               |
|--------|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24]   | RWC | adpprbintmsk | ADB probe interrupt mask<br>0: masked<br>1: not masked<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                                       |
| [23]   | RWC | adptoutint   | ADP timeout interrupt<br>Setting this bit to 1 clears the interrupt.<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                         |
| [22]   | RWC | adpsnsint    | ADP sense interrupt<br>Setting this bit to 1 clears the interrupt.<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                           |
| [21]   | RWC | adpprbint    | ADP probe interrupt<br>Setting this bit to 1 clears the interrupt.<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                           |
| [20]   | RW  | adpen        | ADP enable<br>0: disabled<br>1: enabled<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                                                      |
| [19]   | RWC | adpres       | ADP reset<br>0: not reset<br>+1: reset<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                                                       |
| [18]   | RW  | enasns       | Sense enable<br>0: disabled<br>1: enabled<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                                                    |
| [17]   | RW  | enaprb       | Probe enable<br>0: disabled<br>1: enabled<br>Note: This bit is valid only when GOTGCTL[20] (OTG_Ver) is 1.                                                                    |
| [16:6] | RO  | rtime        | Ramp time<br>The following is the mapping between the values and 32 kHz<br>clock cycle:<br>0x000: 1 cycles<br>0x001: 2 cycles<br>0x002: 3 cycles<br>...<br>0x7FF: 2048 cycles |



|       |    |          |                                                                                                                                                        |
|-------|----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:4] | RW | prbper   | Probe period<br>00: 0.625s to 0.925s (0.775s typically)<br>01: 1.25s to 1.85s (1.55s typically)<br>10: 1.9s to 2.6s (2.275s typically)<br>11: reserved |
| [3:2] | RW | prbdelta | Probe delta<br>The following is the mapping between the values and 32 kHz clock cycle:<br>00: 1 cycle<br>01: 2 cycles<br>10: 3 cycles<br>11: 4 cycles  |
| [1:0] | RW | prbdschg | Probe discharge<br>TADP_DSCHG time<br>00: 4 ms<br>01: 8 ms<br>10: 16 ms<br>11: 32 ms                                                                   |

HPTXFSIZ

HPTXFSIZ is a TX FIFO configuration register.

| Offset Address |         |            |    |    |                                                              |    |    | Register Name |    |    |    |    |            |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|---------|------------|----|----|--------------------------------------------------------------|----|----|---------------|----|----|----|----|------------|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0100         |         |            |    |    |                                                              |    |    | HPTXFSIZ      |    |    |    |    |            |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30         | 29 | 28 | 27                                                           | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19         | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | ptxfsiz |            |    |    |                                                              |    |    |               |    |    |    |    | ptxfstaddr |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0       | 0          | 0  | 0  | 0                                                            | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access  | Name       |    |    | Description                                                  |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RO/RW   | ptxfsiz    |    |    | Depth of the host periodic TX FIFO, ranging from 16 to 32768 |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RO/RW   | ptxfstaddr |    |    | Start address for the host periodic TX FIFO                  |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

DPTXFSIZN

DPTXFSIZN is a device periodic TX FIFO-*n* size register.



This register is valid only in shared FIFO mode.



DIEPTXFN

DIEPTXFN is a device IN endpoint TX FIFO size register.



**NOTE**

This register is valid only in dedicated FIFO mode.

DCFG

DCFG is a device configuration register.



| Offset Address |          |              |    |    |                                                                                                                                                         |         |          | Register Name |    |    |          |    |    |    |            | Total Reset Value |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
|----------------|----------|--------------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------|---------------|----|----|----------|----|----|----|------------|-------------------|---------|----|----|----|--------------|--------------|-------|---|---|---|---|---|---|---|---|---|
| 0x0800         |          |              |    |    |                                                                                                                                                         |         |          | DCFG          |    |    |          |    |    |    |            | 0x8100_0000       |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30           | 29 | 28 | 27                                                                                                                                                      | 26      | 25       | 24            | 23 | 22 | 21       | 20 | 19 | 18 | 17         | 16                | 15      | 14 | 13 | 12 | 11           | 10           | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | resvalid |              |    |    | perschintvl                                                                                                                                             | descdma | epmiscnt |               |    |    | reserved |    |    |    | endevotnak | perfrint          | devaddr |    |    |    | ena32khzsusp | nzstsouthshk | dvspd |   |   |   |   |   |   |   |   |   |
| Reset          | 1        | 0            | 0  | 0  | 0                                                                                                                                                       | 0       | 1        | 0             | 0  | 0  | 0        | 0  | 0  | 0  | 0          | 0                 | 0       | 0  | 0  | 0  | 0            | 0            | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name         |    |    | Description                                                                                                                                             |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [31:26]        | RW       | resvalid     |    |    | Resume time control<br>This bit is valid only when DCFG[ena32khzsusp] is 1.                                                                             |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [25:24]        | RW       | perschintvl  |    |    | Ratio of the (micro) frames in scatter/gather DMA mode<br>00: 25% of (micro)frame<br>01: 50% of (micro)frame<br>10: 75% of (micro)frame<br>11: reserved |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [23]           | RW       | descdma      |    |    | Scatter/Gather DMA enable in device mode<br>0: disabled<br>1: enabled                                                                                   |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [22:18]        | RW       | epmiscnt     |    |    | IN endpoint mismatch statistics                                                                                                                         |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [17:14]        | RW       | reserved     |    |    | Reserved                                                                                                                                                |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [13]           | RW       | endevotnak   |    |    | Device OUT NAK enable<br>0: disabled<br>1: enabled                                                                                                      |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [12:11]        | RW       | perfrint     |    |    | Periodic frame interval<br>00: 80% of the (micro)frame interval<br>01: 85%<br>10: 90%<br>11: 95%                                                        |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [10:4]         | RW       | devaddr      |    |    | Device address                                                                                                                                          |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [3]            | RW       | ena32khzsusp |    |    | 32 kHz suspend mode enable<br>0: disabled<br>1: enabled                                                                                                 |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |
| [2]            | RW       | nzstsouthshk |    |    | Non-zero-length status OUT handshake select                                                                                                             |         |          |               |    |    |          |    |    |    |            |                   |         |    |    |    |              |              |       |   |   |   |   |   |   |   |   |   |



|       |    |        |                                                                                                                                                                                                                                    |
|-------|----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | RW | devspd | Device speed<br>00: high speed (30 MHz or 60 MHz USB 2.0 PHY clock)<br>01: full speed (30 MHz or 60 MHz USB 2.0 PHY clock)<br>10: low speed (6 MHz USB 1.1 transceiver clock)<br>11: full speed (48 MHz USB 1.1 transceiver clock) |
|-------|----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## DCTL

DCTL is a device control register.

|         | Offset Address 0x0804 |             |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name DCTL |           |            |     |          |            |         |           | Total Reset Value 0x0000_0002 |        |            |          |           |            |   |   |
|---------|-----------------------|-------------|--------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-----------|------------|-----|----------|------------|---------|-----------|-------------------------------|--------|------------|----------|-----------|------------|---|---|
| Bit     | 31                    | 30          | 29                                                                                               | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                 | 14        | 13         | 12  | 11       | 10         | 9       | 8         | 7                             | 6      | 5          | 4        | 3         | 2          | 1 | 0 |
| Name    | reserved              |             |                                                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    | encontonbna        | nakonbble | ignrfrmnum | gmc | reserved | pwrnrgdone | cgnpmak | sgnmpmaks | sgnppmaks                     | tstctl | goutnaksts | gnppmaks | sftdiscon | rmtwkpisig |   |   |
| Reset   | 0                     | 0           | 0                                                                                                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                  | 0         | 0          | 0   | 0        | 0          | 0       | 0         | 0                             | 0      | 0          | 0        | 1         | 0          |   |   |
| Bits    | Access                | Name        | Description                                                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [31:18] | RW                    | reserved    | Reserved                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [17]    | RW                    | encontonbna | Continue on BNA enable<br>0: disabled<br>1: enabled                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [16]    | RW                    | nakonbble   | NAK on babble error<br>0: no operation<br>1: NAK configured on the received babble               |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [15]    | RW                    | ignrfrmnum  | Whether the number of frames on isochronous endpoints is ignored<br>0: not ignored<br>1: ignored |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [14:13] | RW                    | gmc         | Global multi count<br>0: invalid<br>01: 1 packet<br>10: 2 packets<br>11: 3 packets               |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |
| [12]    | RW                    | reserved    | Reserved                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |           |            |     |          |            |         |           |                               |        |            |          |           |            |   |   |



|       |    |              |                                                                                                                                                                                        |
|-------|----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11]  | RW | pwrонprgdone | Wakeup from the power-down mode<br>0: not woken up<br>1: woken up                                                                                                                      |
| [10]  | WO | cгoutnak     | Global OUT NAK clear<br>0: no operation<br>1: cleared                                                                                                                                  |
| [9]   | WO | sгoutnak     | Global OUT NAK<br>0: no operation<br>1: configured                                                                                                                                     |
| [8]   | WO | cgnpinnak    | Global non-periodic IN NAK clear<br>0: no operation<br>1: cleared                                                                                                                      |
| [7]   | WO | sgnpinnak    | Global non-periodic IN NAK<br>0: no operation<br>1: configured                                                                                                                         |
| [6:4] | RW | tstctl       | Test control<br>000: test mode disabled<br>001: Test_J mode<br>010: Test_K mode<br>011: Test_SE0_NAK mode<br>100: Test_Packet mode<br>101: Test_Force_Enable<br>Other values: reserved |
| [3]   | RO | goutnaksts   | Global OUT NAK status<br>0: handshake TX<br>1: NAK handshake TX                                                                                                                        |
| [2]   | RO | gnpinnaksts  | Global non-periodic IN NAK status<br>0: handshake TX<br>1: NAK handshake TX                                                                                                            |
| [1]   | RW | sftdiscon    | Soft disconnection<br>0: common mode<br>1: The core drives phy_opmode_o to 2'b01, and then triggers USB disconnection.                                                                 |
| [0]   | RW | rmtwkupsig   | Remote wakeup signal TX<br>0: not woken up remotely<br>1: woken up remotely                                                                                                            |



## DSTS

DSTS is a device status query register.

|         | Offset Address |           |    |    |                                                                                                                                                                                           |    |    |    |    |    | Register Name |       |    |    |    |    |    |    |    |    | Total Reset Value |          |           |         |        |   |   |   |   |   |   |   |  |
|---------|----------------|-----------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|---------------|-------|----|----|----|----|----|----|----|----|-------------------|----------|-----------|---------|--------|---|---|---|---|---|---|---|--|
|         | 0x0808         |           |    |    |                                                                                                                                                                                           |    |    |    |    |    | DSTS          |       |    |    |    |    |    |    |    |    | 0x0007_FF02       |          |           |         |        |   |   |   |   |   |   |   |  |
| Bit     | 31             | 30        | 29 | 28 | 27                                                                                                                                                                                        | 26 | 25 | 24 | 23 | 22 | 21            | 20    | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11                | 10       | 9         | 8       | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name    | reserved       |           |    |    |                                                                                                                                                                                           |    |    |    |    |    | devlnsts      | soffn |    |    |    |    |    |    |    |    |                   | reserved | errticerr | enumspd | suspst |   |   |   |   |   |   |   |  |
| Reset   | 0              | 0         | 0  | 0  | 0                                                                                                                                                                                         | 0  | 0  | 0  | 0  | 0  |               | 0     | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                 | 1        | 1         | 0       | 0      | 0 | 0 | 0 | 0 | 0 | 0 |   |  |
| Bits    | Access         | Name      |    |    | Description                                                                                                                                                                               |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [31:24] | RW             | reserved  |    |    | Reserved                                                                                                                                                                                  |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [23:22] | RO             | devlnsts  |    |    | Logic level of the current USB data line<br>Bit[23]: Logic level of D+<br>Bit[22]: Logic level of D-                                                                                      |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [21:8]  | RO             | soffn     |    |    | Number of frames or micro frames in the received SOF packets                                                                                                                              |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [7:4]   |                | reserved  |    |    | Reserved                                                                                                                                                                                  |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [3]     | RO             | errticerr |    |    | Irregular error                                                                                                                                                                           |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [2:1]   | RO             | enumspd   |    |    | Enumeration speed<br>00: high speed (30 MHz or 60 MHz PHY clock)<br>01: full speed (30 MHz or 60 MHz PHY clock)<br>10: low speed (6 MHz PHY clock).<br>11: full speed (48 MHz PHY clock). |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |
| [0]     | RO             | suspst    |    |    | Suspend status. When the suspend conditions are detected, this bit is 1.                                                                                                                  |    |    |    |    |    |               |       |    |    |    |    |    |    |    |    |                   |          |           |         |        |   |   |   |   |   |   |   |  |

## DIEPMSK

DIEPMSK is a common interrupt mask register for device IN endpoints.





|     |    |              |                                                                  |
|-----|----|--------------|------------------------------------------------------------------|
| [1] | RW | epdisbldmsk  | Endpoint disabled interrupt mask<br>0: masked<br>1: not masked   |
| [0] | RW | xfercomplmsk | Transfer completion interrupt mask<br>0: masked<br>1: not masked |

## DOEPMSK

DOEPMSK is a common interrupt mask register for device OUT endpoints.

|         | Offset Address<br>0x0814 |               |                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>DOEPMSK |        |            |          |               |              |          |                   | Total Reset Value<br>0x0000_0000 |                |          |           |             |              |   |   |
|---------|--------------------------|---------------|-----------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|--------|------------|----------|---------------|--------------|----------|-------------------|----------------------------------|----------------|----------|-----------|-------------|--------------|---|---|
| Bit     | 31                       | 30            | 29                                                        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14     | 13         | 12       | 11            | 10           | 9        | 8                 | 7                                | 6              | 5        | 4         | 3           | 2            | 1 | 0 |
| Name    | reserved                 |               |                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    | nyetmsk                  | nakmsk | bbleerrmsk | reserved | bnaoutintrmsk | outpktermask | reserved | back2backsetupmsk | sisphservdmsk                    | outtknepdismsk | setupmsk | ahberrmsk | epdisbldmsk | xfercomplmsk |   |   |
| Reset   | 0                        | 0             | 0                                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0      | 0          | 0        | 0             | 0            | 0        | 0                 | 0                                | 0              | 0        | 0         | 0           |              |   |   |
| Bits    | Access                   | Name          | Description                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [31:15] | RW                       | reserved      | Reserved                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [14]    | RW                       | nyetmsk       | NYET interrupt mask<br>0: masked<br>1: not masked         |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [13]    | RW                       | nakmsk        | NAK interrupt mask<br>0: masked<br>1: not masked          |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [12]    | RW                       | bbleerrmsk    | Babble error interrupt mask<br>0: masked<br>1: not masked |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [11:10] |                          | reserved      | Reserved                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |
| [9]     | RW                       | bnaoutintrmsk | BNA interrupt mask<br>0: masked<br>1: not masked          |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |        |            |          |               |              |          |                   |                                  |                |          |           |             |              |   |   |



|     |    |                   |                                                                                    |
|-----|----|-------------------|------------------------------------------------------------------------------------|
| [8] | RW | outpkterrmsk      | OUT packet error interrupt mask<br>0: masked<br>1: not masked                      |
| [7] | RW | reserved          | Reserved                                                                           |
| [6] | RW | back2backsetupmsk | Back-to-back setup packets RX interrupt mask<br>0: masked<br>1: not masked         |
| [5] | RW | stsphsercvdmsk    | Status phase RX interrupt mask<br>0: masked<br>1: not masked                       |
| [4] | RW | outtknepdismsk    | W OUT token RX when endpoint disabled interrupt mask<br>0: masked<br>1: not masked |
| [3] | RW | setupmsk          | Setup phase done interrupt mask<br>0: masked<br>1: not masked                      |
| [2] | RW | ahberrmsk         | AHB error interrupt mask<br>0: masked<br>1: not masked                             |
| [1] | RW | epdisbldmsk       | Endpoint disabled interrupt mask<br>0: masked<br>1: not masked                     |
| [0] | RW | xfercomplmsk      | Transfer completion interrupt mask<br>0: masked<br>1: not masked                   |

## DAINT

DAINT is an interrupt register for all device endpoints.



| Offset Address |          |          |    |    |    |                                                                                    |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0818         |          |          |    |    |    |                                                                                    |    |    |    |    |    |    |    |    |    | DAINT         |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                                                 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | outepint |          |    |    |    |                                                                                    |    |    |    |    |    |    |    |    |    |               | inepint |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name     |    |    |    | Description                                                                        |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | RO       | outepint |    |    |    | OUT endpoint interrupt<br>Bit 16: OUT endpoint 0<br>...<br>Bit 31: OUT endpoint 15 |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RO       | inepint  |    |    |    | IN endpoint interrupt<br>Bit 0: IN endpoint 0<br>...<br>Bit 15: IN endpoint 15     |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DAINTMSK

DAINTMSK is an interrupt mask register for all endpoints.

| Offset Address |          |          |    |    |    |                                                                                         |    |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|-----------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x081C         |          |          |    |    |    |                                                                                         |    |    |    |    |    |    |    |    |    | DAINTMSK      |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                                                      | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | outepmsk |          |    |    |    |                                                                                         |    |    |    |    |    |    |    |    |    |               | inepmsk |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name     |    |    |    | Description                                                                             |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | RW       | outepmsk |    |    |    | OUT endpoint interrupt mask<br>Bit 16: OUT endpoint 0<br>...<br>Bit 31: OUT endpoint 15 |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | inepmsk  |    |    |    | IN endpoint interrupt mask<br>Bit 0: IN endpoint 0<br>...<br>Bit 15: IN endpoint 15     |    |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DTKNQR1

DTKNQR1 is device IN token sequence learning queue read register 1.



DTKNQR2

DTKNQR2 is device IN token sequence learning queue read register 2.



DTKNQR3

DTKNQR3 is device IN token sequence learning queue read register 3.

| Offset Address |        |       |    |                                                                                                                                                                                                   |    |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|--------|-------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0830         |        |       |    |                                                                                                                                                                                                   |    |    |    | DTKNQR3       |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31     | 30    | 29 | 28                                                                                                                                                                                                | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | eptkn  |       |    |                                                                                                                                                                                                   |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0     | 0  | 0                                                                                                                                                                                                 | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access | Name  |    | Description                                                                                                                                                                                       |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RO     | eptkn |    | Endpoint token<br>Bits[31:28]: Endpoint number of token 21<br>Bits[27:24]: Endpoint number of token 20<br>...<br>Bits[7:4]: Endpoint number of token 15<br>Bits[3:0]: Endpoint number of token 14 |    |    |    |               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

DTKNQR4

DTKNQR4 is device IN token sequence learning queue read register 4.

DVBUSDIS

DVBUSDIS is a device Vbus discharge time register.



| Offset Address |          |          |    |    |    |                            |    |    |    |    |    |    |    |    |    | Register Name |          |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|----------------------------|----|----|----|----|----|----|----|----|----|---------------|----------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x0828         |          |          |    |    |    |                            |    |    |    |    |    |    |    |    |    | DVBUSDIS      |          |    |    |    |    |    |   | 0x0000_17D7       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                         | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |    |                            |    |    |    |    |    |    |    |    |    |               | dvbusdis |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0        | 0  | 0  | 0  | 0  | 1  | 1 | 1                 | 1 | 1 | 1 | 0 | 1 | 1 | 1 |   |
| Bits           | Access   | Name     |    |    |    | Description                |    |    |    |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved |    |    |    | Reserved                   |    |    |    |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | dvbusdis |    |    |    | Device Vbus discharge time |    |    |    |    |    |    |    |    |    |               |          |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DVBUSPULSE

DVBUSPULSE is a device Vbus pulse time register.

| Offset Address |          |            |    |    |    |                        |    |    |    |    |    |    |    |    |    | Register Name |            |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |
|----------------|----------|------------|----|----|----|------------------------|----|----|----|----|----|----|----|----|----|---------------|------------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|
| 0x082C         |          |            |    |    |    |                        |    |    |    |    |    |    |    |    |    | DVBUSPULSE    |            |    |    |    |    |    |   | 0x0000_05B8       |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30         | 29 | 28 | 27 | 26                     | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |            |    |    |    |                        |    |    |    |    |    |    |    |    |    |               | dvbuspulse |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0          | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0          | 0  | 0  | 0  | 0  | 1  | 0 | 1                 | 1 | 1 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name       |    |    |    | Description            |    |    |    |    |    |    |    |    |    |               |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [31:12]        |          | reserved   |    |    |    | Reserved               |    |    |    |    |    |    |    |    |    |               |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |
| [11:0]         | RO       | dvbuspulse |    |    |    | Device Vbus pulse time |    |    |    |    |    |    |    |    |    |               |            |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |

## DTHRCTL

DTHRCTL is a device threshold control register.



| Offset Address |          |             |          |                                                                                                                                                                               |          |    |    |    |    |    |    |    |         |    |          | Register Name |             |          |    |    |    |    |   | Total Reset Value |   |          |             |   |   |   |   |   |
|----------------|----------|-------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|----|----|----|----|----|----|---------|----|----------|---------------|-------------|----------|----|----|----|----|---|-------------------|---|----------|-------------|---|---|---|---|---|
|                | 0x0830   |             |          |                                                                                                                                                                               |          |    |    |    |    |    |    |    |         |    |          | DTHRCTL       |             |          |    |    |    |    |   | 0x0C10_0020       |   |          |             |   |   |   |   |   |
| Bit            | 31       | 30          | 29       | 28                                                                                                                                                                            | 27       | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18 | 17       | 16            | 15          | 14       | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6        | 5           | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |             | arbprken | reserved                                                                                                                                                                      | rxthrlen |    |    |    |    |    |    |    | rxthren |    | reserved |               | ahbthrratio | txthrlen |    |    |    |    |   |                   |   | isothren | nonisothren |   |   |   |   |   |
| Reset          | 0        | 0           | 0        | 0                                                                                                                                                                             | 1        | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0       | 0  | 0        | 0             | 0           | 0        | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 1        | 0           | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name        |          | Description                                                                                                                                                                   |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [31:28]        | RW       | reserved    |          | Reserved                                                                                                                                                                      |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [27]           | RW       | arbprken    |          | Arbitrator parking enable<br>0: disabled<br>1: enabled                                                                                                                        |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [26]           | RW       | reserved    |          | Reserved                                                                                                                                                                      |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [25:17]        | RW       | rxthrlen    |          | RX threshold length                                                                                                                                                           |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [16]           | RW       | rxthren     |          | RX threshold enable                                                                                                                                                           |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [15:13]        | RW       | reserved    |          | Reserved                                                                                                                                                                      |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [12:11]        | RW       | ahbthrratio |          | AHB threshold ratio<br>00: AHB threshold = MAC threshold<br>01: AHB threshold = MAC threshold/2<br>10: AHB threshold = MAC threshold/4<br>11: AHB threshold = MAC threshold/8 |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [10:2]         | RW       | txthrlen    |          | TX threshold length                                                                                                                                                           |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [1]            | RW       | isothren    |          | ISO IN endpoint threshold enable<br>0: disabled<br>1: enabled                                                                                                                 |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |
| [0]            | RW       | nonisothren |          | Non-ISO IN endpoint threshold enable<br>0: disabled<br>1: enabled                                                                                                             |          |    |    |    |    |    |    |    |         |    |          |               |             |          |    |    |    |    |   |                   |   |          |             |   |   |   |   |   |

## DIEPEMPMSK

DIEPEMPMSK is a FIFO empty interrupt mask register for device IN endpoints.



| Offset Address |          |               |    |    |                                                                                             |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|---------------|----|----|---------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0834         |          |               |    |    |                                                                                             |    |    | DIEPEMPMSK    |    |    |    |    |    |    |    | 0x0000_0000       |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30            | 29 | 28 | 27                                                                                          | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |               |    |    |                                                                                             |    |    |               |    |    |    |    |    |    |    |                   | ineptxfempmsk |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0             | 0  | 0  | 0                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name          |    |    | Description                                                                                 |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved      |    |    | Reserved                                                                                    |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | ineptxfempmsk |    |    | IN EP TX FIFO empty interrupt mask<br>Bit 0: IN endpoint 0<br>...<br>Bit 15: IN endpoint 15 |    |    |               |    |    |    |    |    |    |    |                   |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

DEACHINT

DEACHINT is an interrupt register for each device endpoint.

| Offset Address |             |             |    |    |                                                                                                      |    |    | Register Name |    |    |    |    |            |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-------------|-------------|----|----|------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|------------|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0838         |             |             |    |    |                                                                                                      |    |    | DEACHINT      |    |    |    |    |            |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31          | 30          | 29 | 28 | 27                                                                                                   | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19         | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | echoutepint |             |    |    |                                                                                                      |    |    |               |    |    |    |    | echinepint |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0           | 0           | 0  | 0  | 0                                                                                                    | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access      | Name        |    |    | Description                                                                                          |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW          | echoutepint |    |    | OUT endpoint interrupt<br>Bit 16 controls OUT endpoint 0.<br>...<br>Bit 31 controls OUT endpoint 15. |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW          | echinepint  |    |    | IN endpoint interrupt<br>Bit 15 controls IN endpoint 0.<br>...<br>Bit 0 controls IN endpoint 15.     |    |    |               |    |    |    |    |            |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

DEACHINTMSK

**DEACHINTMSK** is an interrupt mask register for each device endpoint.



| Offset Address |             |             |    |    |    |                                                                                                                                         |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|-------------|-------------|----|----|----|-----------------------------------------------------------------------------------------------------------------------------------------|----|---------------|----|----|----|----|----|----|----|-------------------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x083C         |             |             |    |    |    |                                                                                                                                         |    | DEACHINTMSK   |    |    |    |    |    |    |    | 0x0000_0000       |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31          | 30          | 29 | 28 | 27 | 26                                                                                                                                      | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | echoutepmsk |             |    |    |    |                                                                                                                                         |    |               |    |    |    |    |    |    |    |                   | echinepmsk |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0           | 0           | 0  | 0  | 0  | 0                                                                                                                                       | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access      | Name        |    |    |    | Description                                                                                                                             |    |               |    |    |    |    |    |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW          | echoutepmsk |    |    |    | OUT endpoint interrupt mask<br>Bit 16 controls OUT endpoint 0.<br>...<br>Bit 31 controls OUT endpoint 15.<br>0: masked<br>1: not masked |    |               |    |    |    |    |    |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW          | echinepmsk  |    |    |    | IN Endpoint interrupt mask<br>Bit 16 controls IN endpoint 0.<br>...<br>Bit 31 controls IN endpoint 15.<br>0: masked<br>1: not masked    |    |               |    |    |    |    |    |    |    |                   |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## DIEPEACHMSKN

DIEPEACHMSKN is an interrupt register for device IN endpoint  $n$ .



|         |    |                |                                                                                   |
|---------|----|----------------|-----------------------------------------------------------------------------------|
| [13]    | RW | nakmsk         | NAK interrupt mask<br>0: masked<br>1: not masked                                  |
| [12:10] | -  | reserved       | Reserved                                                                          |
| [9]     | RW | bmainintrmsk   | BNA interrupt mask<br>0: masked<br>1: not masked                                  |
| [8]     | RW | txfifoundrnmsk | FIFO underrun interrupt mask<br>0: masked<br>1: not masked                        |
| [7]     | -  | reserved       | Reserved                                                                          |
| [6]     | RW | inepnakeffmsk  | IN endpoint NAK effective interrupt mask<br>0: masked<br>1: not masked            |
| [5]     | RW | intknepmismsk  | IN token received with EP mismatch interrupt mask<br>0: masked<br>1: not masked   |
| [4]     | RW | intkntxfempmsk | IN token received when TX FIFO empty interrupt mask<br>0: masked<br>1: not masked |
| [3]     | RW | timeoutmsk     | Timeout interrupt mask (non-isochronous endpoints)<br>0: masked<br>1: not masked  |
| [2]     | RW | ahberrmsk      | AHB error interrupt mask<br>0: masked<br>1: not masked                            |
| [1]     | RW | epdisbldmsk    | Endpoint disable interrupt mask<br>0: masked<br>1: not masked                     |
| [0]     | RW | xfercomplmsk   | Transfer completion interrupt mask<br>0: masked<br>1: not masked                  |

## DOEPEACHMSKN

DOEPEACHMSKN is an interrupt register for device OUT endpoint *n*.



|         | Offset Address                                                                                                                                                | Register Name  | Total Reset Value                                                                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------|
|         | 0x0880 + (0x0004 x n)<br>(n = 0–15)                                                                                                                           | DOEPEACHMSKN   |                                                                                  |
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0                                                           |                |                                                                                  |
| Name    | reserved                                                                                                                                                      |                |                                                                                  |
| Reset   | 0 0 0 0   0 0 0 0   1 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                |                                                                                  |
| Bits    | Access                                                                                                                                                        | Name           | Description                                                                      |
| [31:15] | -                                                                                                                                                             | reserved       | Reserved                                                                         |
| [14]    | RW                                                                                                                                                            | nyetmsk        | NYET interrupt mask<br>0: masked<br>1: not masked                                |
| [13]    | RW                                                                                                                                                            | nakmsk         | NAK interrupt mask<br>0: masked<br>1: not masked                                 |
| [12]    | RW                                                                                                                                                            | bbleerrmsk     | Babble error interrupt mask<br>0: masked<br>1: not masked                        |
| [11:10] | -                                                                                                                                                             | reserved       | Reserved                                                                         |
| [9]     | RW                                                                                                                                                            | bnaoutintrmsk  | BNA interrupt mask<br>0: masked<br>1: not masked                                 |
| [8]     | RW                                                                                                                                                            | outpkterrmsk   | OUT packet error interrupt mask<br>0: masked<br>1: not masked                    |
| [7]     | -                                                                                                                                                             | reserved       | Reserved                                                                         |
| [6]     | RW                                                                                                                                                            | back2backsetup | Back-to-back setup packets RX interrupt mask<br>0: masked<br>1: not masked       |
| [5]     | -                                                                                                                                                             | reserved       | Reserved                                                                         |
| [4]     | RW                                                                                                                                                            | outtknepdismsk | OUT token RX when endpoint disabled interrupt mask<br>0: masked<br>1: not masked |



|     |    |              |                                                                  |
|-----|----|--------------|------------------------------------------------------------------|
| [3] | RW | setupmsk     | Setup phase done interrupt mask<br>0: masked<br>1: not masked    |
| [2] | RW | ahberrmsk    | AHB error interrupt mask<br>0: masked<br>1: not masked           |
| [1] | RW | epdisbldmsk  | Endpoint disabled interrupt mask<br>0: masked<br>1: not masked   |
| [0] | RW | xfercomplmsk | Transfer completion interrupt mask<br>0: masked<br>1: not masked |

## DIEPCTL0

DIEPCTL0 is a control register for device control IN endpoint 0.

| Offset Address |        |       |          |      |      |                                                                                  |    |    |       | Register Name |        |        |          |          |        |    |    |          |    | Total Reset Value |    |    |     |   |   |   |   |   |   |   |   |   |
|----------------|--------|-------|----------|------|------|----------------------------------------------------------------------------------|----|----|-------|---------------|--------|--------|----------|----------|--------|----|----|----------|----|-------------------|----|----|-----|---|---|---|---|---|---|---|---|---|
| 0x0900         |        |       |          |      |      |                                                                                  |    |    |       | DIEPCTL0      |        |        |          |          |        |    |    |          |    | 0x0000_8000       |    |    |     |   |   |   |   |   |   |   |   |   |
| Bit            | 31     | 30    | 29       | 28   | 27   | 26                                                                               | 25 | 24 | 23    | 22            | 21     | 20     | 19       | 18       | 17     | 16 | 15 | 14       | 13 | 12                | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | epena  | epdis | reserved | snak | cnak | txfnum                                                                           |    |    | stall | reserved      | eptype | naksts | reserved | usbactep | nextep |    |    | reserved |    |                   |    |    | mps |   |   |   |   |   |   |   |   |   |
| Reset          | 0      | 0     | 0        | 0    | 0    | 0                                                                                | 0  | 0  | 0     | 0             | 0      | 0      | 0        | 0        | 0      | 1  | 0  | 0        | 0  | 0                 | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access |       | Name     |      |      | Description                                                                      |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [31]           | RWSC   |       | epena    |      |      | Endpoint enable<br>0: disabled<br>1: transfer completed                          |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [30]           | RWSC   |       | epdis    |      |      | Endpoint disable<br>This bit is enabled only in DMA mode.                        |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [29:28]        | -      |       | reserved |      |      | Reserved                                                                         |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [27]           | WO     |       | snak     |      |      | NAK setting                                                                      |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [26]           | WO     |       | cnak     |      |      | NAK clear                                                                        |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [25:22]        | RW     |       | txfnum   |      |      | Number of TX FIFOs                                                               |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |
| [21]           | RWSC   |       | stall    |      |      | Stall handshake<br>This bit is cleared when the endpoint receives a setup token. |    |    |       |               |        |        |          |          |        |    |    |          |    |                   |    |    |     |   |   |   |   |   |   |   |   |   |



|         |    |          |                                                                                       |
|---------|----|----------|---------------------------------------------------------------------------------------|
| [20]    | -  | reserved | Reserved                                                                              |
| [19:18] | RO | eptype   | Endpoint type                                                                         |
| [17]    | RO | naksts   | NAK status<br>0: non-NAK handshake TX<br>1: NAK handshake TX                          |
| [16]    | -  | reserved | Reserved                                                                              |
| [15]    | RO | usbactep | USB-activated endpoint                                                                |
| [14:11] | -  | nextep   | Next endpoint<br>This field specifies the ID of the next endpoint that receives data. |
| [10:2]  | -  | reserved | Reserved                                                                              |
| [1:0]   | RW | mps      | Minimum packet size<br>00: 64 bytes<br>01: 32 bytes<br>10: 16 bytes<br>11: 8 bytes    |

## DOEPCTL0

DOEPCTL0 is a control register for device control OUT endpoint 0.



| Offset Address |       |        |          |          |      |      |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |       | Register Name |        |        |          |          |          |    |    |    |    |    |   | Total Reset Value |     |   |   |   |   |   |   |   |  |  |  |
|----------------|-------|--------|----------|----------|------|------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-------|---------------|--------|--------|----------|----------|----------|----|----|----|----|----|---|-------------------|-----|---|---|---|---|---|---|---|--|--|--|
| 0x0B00         |       |        |          |          |      |      |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |       | DOEPCTL0      |        |        |          |          |          |    |    |    |    |    |   | 0x0000_8000       |     |   |   |   |   |   |   |   |  |  |  |
| Bit            | 31    | 30     | 29       | 28       | 27   | 26   | 25       | 24                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 23 | 22 | 21    | 20            | 19     | 18     | 17       | 16       | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | epena | epdis  | reserved |          | snak | cnak | reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    | stall | snp           | eptype | naksts | reserved | usbactep | reserved |    |    |    |    |    |   |                   | mps |   |   |   |   |   |   |   |  |  |  |
| Reset          | 0     | 0      | 0        | 0        | 0    | 0    | 0        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0  | 0  | 0     | 0             | 0      | 0      | 0        | 1        | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0   | 0 | 0 | 0 | 0 | 0 |   |   |  |  |  |
| Bits           |       | Access |          | Name     |      |      |          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [31]           |       | RWSC   |          | epena    |      |      |          | Endpoint enable<br>When the scatter/gather DMA is enabled:<br>0: The descriptor structure and the data RX function of the data buffer are disabled.<br>1: The descriptor structure and the data RX function of the data buffer are enabled.<br>When the scatter/gather DMA is disabled:<br>0: The function of receiving data from the USB module to the memory is disabled.<br>1: The function of receiving data from the USB module to the memory is enabled. |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [30]           |       | RO     |          | epdis    |      |      |          | Endpoint disable                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [29:28]        |       | -      |          | reserved |      |      |          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [27]           |       | WO     |          | snak     |      |      |          | NAK setting                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [26]           |       | WO     |          | cnak     |      |      |          | NAK clear                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [25:22]        |       | -      |          | reserved |      |      |          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [21]           |       | RWSC   |          | stall    |      |      |          | Stall handshake                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [20]           |       | RW     |          | snp      |      |      |          | Snoop mode                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [19:18]        |       | RO     |          | eptype   |      |      |          | Endpoint type                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [17]           |       | RO     |          | naksts   |      |      |          | NAK status<br>0: non-NAK handshake TX<br>1: NAK handshake TX                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [16]           |       | -      |          | reserved |      |      |          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [15]           |       | RO     |          | usbactep |      |      |          | USB-activated endpoint                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |
| [14:2]         |       | -      |          | reserved |      |      |          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |       |               |        |        |          |          |          |    |    |    |    |    |   |                   |     |   |   |   |   |   |   |   |  |  |  |



|       |    |     |                                                                                    |
|-------|----|-----|------------------------------------------------------------------------------------|
| [1:0] | RW | mps | Minimum packet size<br>00: 64 bytes<br>01: 32 bytes<br>10: 16 bytes<br>11: 8 bytes |
|-------|----|-----|------------------------------------------------------------------------------------|

## DIEPCTLN

DIEPCTLN is a control register for device IN endpoint  $n$ .

| Bit   | Offset Address<br>0x0900 + (0x0020 x n)<br>(n = 0–15) |                    |                   |      |      |                                                                                                                                                                                                                                                                                                                                                                  |    |    |    |       |      |        |        |               |          |        | Register Name<br>DIEPCTLN |    |    |     |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |
|-------|-------------------------------------------------------|--------------------|-------------------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|-------|------|--------|--------|---------------|----------|--------|---------------------------|----|----|-----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|
|       | 31                                                    | 30                 | 29                | 28   | 27   | 26                                                                                                                                                                                                                                                                                                                                                               | 25 | 24 | 23 | 22    | 21   | 20     | 19     | 18            | 17       | 16     | 15                        | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | EPEna                                                 | EPDis              | SetD1PID_SetOddFr | SNAK | CNAK | TxFNum                                                                                                                                                                                                                                                                                                                                                           |    |    |    | Stall | Sn p | EPType | NAKSis | DPID_EO_FrNum | USBActEP | NextEp |                           |    |    | MPS |    |    |   |   |                                  |   |   |   |   |   |   |   |
| Reset | 0                                                     | 0                  | 0                 | 0    | 0    | 0                                                                                                                                                                                                                                                                                                                                                                | 0  | 0  | 0  | 0     | 0    | 0      | 0      | 0             | 0        | 0      | 0                         | 0  | 0  | 0   | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits  | Access                                                | Name               |                   |      |      | Description                                                                                                                                                                                                                                                                                                                                                      |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [31]  | RWSC                                                  | EPEna              |                   |      |      | Endpoint enable<br>When the scatter/gather DMA is enabled:<br>0: The descriptor structure and the data TX function of the data buffer are disabled.<br>1: The descriptor structure and the data TX function of the data buffer are disabled.<br>When the scatter/gather DMA is disabled:<br>0: Data on endpoints is not ready.<br>1: Data on endpoints is ready. |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [30]  | RWSC                                                  | EPDis              |                   |      |      | Endpoint disable                                                                                                                                                                                                                                                                                                                                                 |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [29]  | WO                                                    | SetD1PID_SetOddFr  |                   |      |      | DATA1 PID/odd frame                                                                                                                                                                                                                                                                                                                                              |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [28]  | WO                                                    | SetD0PID_SetEvenFr |                   |      |      | DATA0 PID or even frame in non-scatter/gather DMA mode<br>Scatter/Gather DMA mode: reserved                                                                                                                                                                                                                                                                      |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [27]  | WO                                                    | SNAK               |                   |      |      | NAK setting                                                                                                                                                                                                                                                                                                                                                      |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [26]  | WO                                                    | CNAK               |                   |      |      | NAK clear                                                                                                                                                                                                                                                                                                                                                        |    |    |    |       |      |        |        |               |          |        |                           |    |    |     |    |    |   |   |                                  |   |   |   |   |   |   |   |



|         |      |               |                                                                                                                                                                                                                          |
|---------|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [25:22] | RW   | TxFNum        | Number of TX FIFOs<br>Shared FIFO operation:<br>0: Non-periodic TX FIFO<br>Other values: specified periodic TX FIFO number<br>Dedicated FIFO operation:<br>Number of FIFOs<br>This field is valid only for IN endpoints. |
| [21]    | RW   | Stall         | Stall handshake (RW)<br>Endpoint control (RWSC)                                                                                                                                                                          |
| [20]    | RW   | Snp           | Snoop mode                                                                                                                                                                                                               |
| [19:18] | RW   | EPType        | Endpoint type<br>00: control<br>01: isochronous<br>10: bulk<br>11: interrupt                                                                                                                                             |
| [17]    | RO   | NAKSts        | NAK status<br>0: non-NAK handshake TX<br>1: NAK handshake TX                                                                                                                                                             |
| [16]    | RO   | DPID_EO_FrNum | Endpoint data PID<br>0: DATA0<br>1: DATA1<br>Even/Odd frame<br>Non-scatter/gather DMA mode:<br>0: even frame<br>1: odd frame<br>Scatter/Gather DMA mode: reserved                                                        |
| [15]    | RWSC | USBActEP      | USB-activated endpoint                                                                                                                                                                                                   |
| [14:11] | RW   | NextEp        | Next endpoint<br>This field specifies the ID of the next endpoint that receives data.                                                                                                                                    |
| [10:0]  | RW   | MPS           | Maximum packet size                                                                                                                                                                                                      |

## DOEPCTLN

DOEPCTLN is a control register for device OUT endpoint *n*.



| Offset Address<br>0x0B00 + (0x0020 x n)<br>(n = 0–15) |        |                    |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |      |        |    |    |    |       | Register Name<br>DOEPCTLN |        |        |    |               |          | Total Reset Value<br>0x0000_0000 |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------------------------|--------|--------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|--------|----|----|----|-------|---------------------------|--------|--------|----|---------------|----------|----------------------------------|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| Bit                                                   | 31     | 30                 | 29                | 28                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 27   | 26   | 25     | 24 | 23 | 22 | 21    | 20                        | 19     | 18     | 17 | 16            | 15       | 14                               | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                                  | EPEna  | EPDis              | SetD1PID_SetOddFr | SetD0PID_SetEvenFr                                                                                                                                                                                                                                                                                                                                                                                                                                             | SNAK | CNAK | TxFNum |    |    |    | Stall | Sn p                      | EPType | NAKSts |    | DPID_EO_FrNum | USBActEP | NextEp                           |    |    |    | MPS |   |   |   |   |   |   |   |   |   |   |
| Reset                                                 | 0      | 0                  | 0                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0    | 0    | 0      | 0  | 0  | 0  | 0     | 0                         | 0      | 0      | 0  | 0             | 0        | 0                                | 0  | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |   |
| Bits                                                  | Access | Name               |                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [31]                                                  | RWSC   | EPEna              |                   | Endpoint enable<br>When the scatter/gather DMA is enabled:<br>0: The descriptor structure and the data RX function of the data buffer are disabled.<br>1: The descriptor structure and the data RX function of the data buffer are enabled.<br>When the scatter/gather DMA is disabled:<br>0: The function of receiving data from the USB module to the memory is disabled.<br>1: The function of receiving data from the USB module to the memory is enabled. |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [30]                                                  | RWSC   | EPDis              |                   | Endpoint disable                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [29]                                                  | WO     | SetD1PID_SetOddFr  |                   | DATA1 PID/odd frame                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [28]                                                  | WO     | SetD0PID_SetEvenFr |                   | DATA0 PID or even frame in non-scatter/gather DMA mode<br>Scatter/Gather DMA mode: reserved                                                                                                                                                                                                                                                                                                                                                                    |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [27]                                                  | WO     | SNAK               |                   | NAK setting                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [26]                                                  | WO     | CNAK               |                   | NAK clear                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
| [25:22]                                               | RW     | TxFNum             |                   | Number of TX FIFOs<br>Shared FIFO operation:<br>0: Non-periodic TX FIFO<br>Other values: specified periodic TX FIFO number<br>Dedicated FIFO operation:<br>Number of FIFOs<br>This field is valid only for IN endpoints.                                                                                                                                                                                                                                       |      |      |        |    |    |    |       |                           |        |        |    |               |          |                                  |    |    |    |     |   |   |   |   |   |   |   |   |   |   |



|         |      |               |                                                                                                                                                                      |
|---------|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [21]    | RW   | Stall         | Stall handshake (RW)<br>Endpoint control (RWSC)                                                                                                                      |
| [20]    | RW   | Snp           | Snoop mode                                                                                                                                                           |
| [19:18] | RW   | EPType        | Endpoint type<br>00: control<br>01: isochronous<br>10: bulk<br>11: interrupt                                                                                         |
| [17]    | RO   | NAKSts        | NAK status<br>0: non-NAK handshake TX<br>1: NAK handshake TX                                                                                                         |
| [16]    | RO   | DPID_EO_FrNum | Endpoint data PID<br>0: DATA0<br>1: DATA1<br>Even/Odd frame<br>Non-scatter/gather DMA mode:<br>0: even frame<br>1: odd frame<br>Scatter/Gather DMA mode:<br>Reserved |
| [15]    | RWSC | USBActEP      | USB-activated endpoint                                                                                                                                               |
| [14:11] | RW   | NextEp        | Next endpoint<br>This field specifies the ID of the next endpoint that receives data.                                                                                |
| [10:0]  | RW   | MPS           | Maximum packet size                                                                                                                                                  |

## DIEPINTn

DIEPINTn is an interrupt register for device IN endpoint  $n$ .



| Offset Address<br>0x0908 + (0x0020 x n)<br>(n = 0–15) |          |               |    |                                                                                                                               |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>DIEPINTn |             |            |           |               |           |          |         | Total Reset Value<br>0x0000_0000 |        |                           |                         |                         |               |        |          |           |
|-------------------------------------------------------|----------|---------------|----|-------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-------------|------------|-----------|---------------|-----------|----------|---------|----------------------------------|--------|---------------------------|-------------------------|-------------------------|---------------|--------|----------|-----------|
| Bit                                                   | 31       | 30            | 29 | 28                                                                                                                            | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        | 15          | 14         | 13        | 12            | 11        | 10       | 9       | 8                                | 7      | 6                         | 5                       | 4                       | 3             | 2      | 1        | 0         |
| Name                                                  | reserved |               |    |                                                                                                                               |    |    |    |    |    |    |    |    |    |    |    |                           | StupPktRcvd | NYETIntrpt | NAKIntrpt | BbleErrIntrpt | PktDrpSts | reserved | BNAIntr | TxfifoUndrm_OutPktErr            | TxFEmp | INEPNakEff_Back2BackSETUp | INTknEPMis_StsPhaseRevd | INTknTXFEmp_OUTTknEPdis | TimeOUT_SetUp | AHBErr | EPDisbld | XferCompl |
| Reset                                                 | 0        | 0             | 0  | 0                                                                                                                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0           | 0          | 0         | 0             | 0         | 0        | 0       | 0                                | 0      | 0                         | 0                       | 0                       | 0             | 0      |          |           |
| Bits                                                  | Access   | Name          |    | Description                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [31:16]                                               | RW       | reserved      |    | Reserved                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [15]                                                  | RWSC     | StupPktRcvd   |    | Whether setup packets are received<br>0: no<br>1: yes                                                                         |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [14]                                                  | RWSC     | NYETIntrpt    |    | NYET interrupt<br>NYET response TX interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                  |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [13]                                                  | RWSC     | NAKIntrpt     |    | NAK interrupt<br>NAK TX interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                             |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [12]                                                  | RWSC     | BbleErrIntrpt |    | Babble error interrupt<br>Endpoint received babble interrupt.<br>0: An interrupt is cleared.<br>1: An interrupt is generated. |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [11]                                                  | RWSC     | PktDrpSts     |    | Packet drop status interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                  |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |
| [10]                                                  | -        | reserved      |    | Reserved                                                                                                                      |    |    |    |    |    |    |    |    |    |    |    |                           |             |            |           |               |           |          |         |                                  |        |                           |                         |                         |               |        |          |           |



|     |      |                           |                                                                                                                                                                                                                                                                                                                                                               |
|-----|------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9] | RWSC | BNAIntr                   | BNA interrupt<br>An interrupt is generated when descriptor access is not ready.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                               |
| [8] | RWSC | TxfifoUndrn_OutPktErr     | FIFO underrun interrupt<br>An interrupt is generated when FIFO underrun occurs.<br>The interrupt is valid when the following conditions are met:<br>-Thresholding enable<br>OUT packet error<br>An interrupt is generated when an overflow or CRC error is detected.<br>The interrupt is valid when the following conditions are met:<br>-Thresholding enable |
| [7] | RO   | TxFEmp                    | TX FIFO empty status interrupt<br>An interrupt is generated when the TX FIFO is empty or half empty.<br>Note: This bit is valid only for IN endpoints.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                        |
| [6] | RWSC | INEPNakEff_Back2BackSETup | IN endpoint NAK effective interrupt<br>An interrupt is generated when the IN endpoint bit is set.<br>Back-to-back setup package received interrupt.<br>An interrupt is generated when the core receives more than three back-to-back setup packets.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                           |
| [5] | RWSC | INTknEPMis_StsPhseRcvd    | An interrupt is generated when the IN tokens with mismatch EP are received.<br>A control write pulse is received.<br>0: An interrupt is cleared.<br>1: A control write pulse is received.                                                                                                                                                                     |
| [4] | RWSC | INTknTXFEmp_OUTTknEPdis   | An interrupt is generated if IN tokens are received when the corresponding TX FIFO is empty.<br>An interrupt is generated if OUT tokens are received when endpoints are disabled.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                             |



|     |      |               |                                                                                                                                                                                                  |
|-----|------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3] | RWSC | TimeOUT_SetUp | Timeout interrupt<br>An interrupt is generated when a timeout is detected.<br>Setup phase done interrupt.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                        |
| [2] | RWSC | AHBErr        | AHB error interrupt<br>An interrupt is generated when an AHB error occurs during AHB read/write operations in internal DMA mode.<br>0: An interrupt is cleared.<br>1: An interrupt is generated. |
| [1] | RWSC | EPDisbld      | Endpoint disable interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                       |
| [0] | -    | XferCompl     | Transfer completion interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                    |

## DOEPINTn

DOEPINTn is an interrupt register for device OUT endpoint *n*.

| Offset Address<br>0x0B08 + (0x0020 x n)<br>(n = 0–15) |          |             |    |    |                                                       |    |    |    |    | Register Name<br>DOEPINTn |    |    |    |    |    |             |            | Total Reset Value<br>0x0000_0000 |             |           |          |         |                       |        |                          |                         |                         |               |        |          |           |   |
|-------------------------------------------------------|----------|-------------|----|----|-------------------------------------------------------|----|----|----|----|---------------------------|----|----|----|----|----|-------------|------------|----------------------------------|-------------|-----------|----------|---------|-----------------------|--------|--------------------------|-------------------------|-------------------------|---------------|--------|----------|-----------|---|
| Bit                                                   | 31       | 30          | 29 | 28 | 27                                                    | 26 | 25 | 24 | 23 | 22                        | 21 | 20 | 19 | 18 | 17 | 16          | 15         | 14                               | 13          | 12        | 11       | 10      | 9                     | 8      | 7                        | 6                       | 5                       | 4             | 3      | 2        | 1         | 0 |
| Name                                                  | reserved |             |    |    |                                                       |    |    |    |    |                           |    |    |    |    |    | StupPktRcvd | NYETIntrpt | NAKIntrpt                        | BleErIntrpt | PltDipSts | reserved | BNALntr | TxfifoUndrv_OutPktErr | TxFEmp | INEPNakEff_Bck2BackSETup | INTknEPMis_SisPhaseRcvd | INTknTXFEmp_OUTTknEPdis | TimeOUT_SetUp | AHBErr | EPDisbld | XferCompl |   |
| Reset                                                 | 0        | 0           | 0  | 0  | 0                                                     | 0  | 0  | 0  | 0  | 0                         | 0  | 0  | 0  | 0  | 0  | 0           | 0          | 0                                | 0           | 0         | 0        | 0       | 0                     | 0      | 0                        | 0                       | 0                       | 0             | 0      | 0        |           |   |
| Bits                                                  | Access   | Name        |    |    | Description                                           |    |    |    |    |                           |    |    |    |    |    |             |            |                                  |             |           |          |         |                       |        |                          |                         |                         |               |        |          |           |   |
| [31:16]                                               | RW       | reserved    |    |    | Reserved                                              |    |    |    |    |                           |    |    |    |    |    |             |            |                                  |             |           |          |         |                       |        |                          |                         |                         |               |        |          |           |   |
| [15]                                                  | RWSC     | StupPktRcvd |    |    | Whether setup packets are received<br>0: no<br>1: yes |    |    |    |    |                           |    |    |    |    |    |             |            |                                  |             |           |          |         |                       |        |                          |                         |                         |               |        |          |           |   |



|      |      |                       |                                                                                                                                                                                                                                                                                                                                                               |
|------|------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14] | RWSC | NYETIntrpt            | NYET interrupt<br>NYET response TX interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                                                  |
| [13] | RWSC | NAKIntrpt             | NAK interrupt<br>NAK TX interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                                                             |
| [12] | RWSC | BbleErrIntrpt         | Babble error interrupt<br>Endpoint received babble interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                                  |
| [11] | RWSC | PktDrpSts             | Packet drop status interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                                                                  |
| [10] | -    | reserved              | Reserved                                                                                                                                                                                                                                                                                                                                                      |
| [9]  | RWSC | BNAIntr               | BNA interrupt<br>An interrupt is generated when descriptor access is not ready.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                               |
| [8]  | RWSC | TxfifoUndrn_OutPktErr | FIFO underrun interrupt<br>An interrupt is generated when FIFO underrun occurs.<br>The interrupt is valid when the following conditions are met:<br>-Thresholding enable<br>OUT packet error<br>An interrupt is generated when an overflow or CRC error is detected.<br>The interrupt is valid when the following conditions are met:<br>-Thresholding enable |
| [7]  | RO   | TxFEMp                | TX FIFO empty status interrupt<br>An interrupt is generated when the TX FIFO is empty or half empty.<br>This bit is valid only for IN endpoints.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                              |



|     |      |                           |                                                                                                                                                                                                                                                                                                                    |
|-----|------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | RWSC | INEPNakEff_Back2BackSETup | IN endpoint NAK effective interrupt<br>An interrupt is generated when the IN endpoint bit is set.<br>Back-to-back setup package received interrupt<br>An interrupt is generated when the core receives more than three back-to-back setup packets.<br>0: An interrupt is cleared.<br>1: An interrupt is generated. |
| [5] | RWSC | INTknEPMis_StsPhseRcvd    | An interrupt is generated when the IN tokens with mismatch EP are received.<br>A control write pulse is received.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                  |
| [4] | RWSC | INTknTXFEmp_OUTTknEPdis   | An interrupt is generated if IN tokens are received when the corresponding TX FIFO is empty.<br>An interrupt is generated if OUT tokens are received when endpoints are disabled.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                  |
| [3] | RWSC | TimeOUT_SetUp             | Timeout interrupt<br>An interrupt is generated when a timeout is detected.<br>Setup phase done interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                           |
| [2] | RWSC | AHBErr                    | AHB error interrupt<br>An interrupt is generated when an AHB error occurs during AHB read/write operations in internal DMA mode.<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                   |
| [1] | RWSC | EPDisblld                 | Endpoint disable interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                         |
| [0] | -    | XferCompl                 | Transfer completion interrupt<br>0: An interrupt is cleared.<br>1: An interrupt is generated.                                                                                                                                                                                                                      |

## DIEPTSIZ0

DIEPTSIZ0 is a transfer size register for device IN endpoint 0.



DOEPTSIZ0

**DOEPTSIZE0** is a transfer size register for device OUT endpoint 0.



DIEPTSIZn

`DIEPTSIZn` is a transfer size register for device IN endpoint  $n$ .

DOEPTSIZn

**DOEPTSIZn** is a transfer size register for device OUT endpoint *n*.



| Offset Address<br>0x0B10 + (0x0020 x n)<br>(n = 0–15) |          |                 |        |                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |          | Register Name<br>DOEPTSIzn |    |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |
|-------------------------------------------------------|----------|-----------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----------|----------------------------|----|----|----|----|----|----|---|----------------------------------|---|---|---|---|---|---|---|---|
| Bit                                                   | 31       | 30              | 29     | 28                                                                                                                                                                                                                                                                                                                                    | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16                         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                                  | reserved | mc_rxpid_supcnt | PktCnt |                                                                                                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    | XferSize |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| Reset                                                 | 0        | 0               | 0      | 0                                                                                                                                                                                                                                                                                                                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits                                                  | Access   | Name            |        | Description                                                                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |    |    |    |          |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [31]                                                  | RW       | reserved        |        | Reserved                                                                                                                                                                                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |          |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [30:29]                                               | RW       | mc_rxpid_supcnt |        | Number of packets (IN endpoint, RW)<br>00: 0 packets<br>01: 1 packet<br>10: 2 packets<br>11: 3 packets<br><br>Number of packets (non-periodic IN endpoints, RO)<br>This field is valid only in internal DMA mode.<br><br>PID of the received data (isochronous OUT endpoints, RO)<br>00: DATA0<br>01: DATA2<br>10: DATA1<br>11: MDATA |    |    |    |    |    |    |    |    |    |    |          |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [28:19]                                               | RW       | PktCnt          |        | Number of packets                                                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |          |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [18:0]                                                | RW       | XferSize        |        | Transferred data size                                                                                                                                                                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |          |                            |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |

## DIEPDMAN

DIEPDMAN is a DMA address register for device IN endpoint *n*.



| Offset Address        |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-----------------------|--------|--------|---------|----|----|----|-------------|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0x0914 + (0x0020 x n) |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    | DIEPDMAN      |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |   |   |   |   |   |
| (n = 0–15)            |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Bit                   | 31     | 30     | 29      | 28 | 27 | 26 | 25          | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |
| Name                  |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    |               | dmaaddr |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset                 | 0      | 0      | 0       | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                       | Bits   | Access | Name    |    |    |    | Description |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                       | [31:0] | RW     | dmaaddr |    |    |    | DMA address |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |

## DOEPDMAN

DOEPDMAN is a DMA address register for device OUT endpoint *n*.

| Offset Address        |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    | Register Name |         |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-----------------------|--------|--------|---------|----|----|----|-------------|----|----|----|----|----|----|----|----|---------------|---------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0x0B14 + (0x0020 x n) |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    | DOEPDMAN      |         |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |   |   |   |   |   |
| (n = 0–15)            |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Bit                   | 31     | 30     | 29      | 28 | 27 | 26 | 25          | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |
| Name                  |        |        |         |    |    |    |             |    |    |    |    |    |    |    |    |               | dmaaddr |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset                 | 0      | 0      | 0       | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                       | Bits   | Access | Name    |    |    |    | Description |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                       | [31:0] | RW     | dmaaddr |    |    |    | DMA address |    |    |    |    |    |    |    |    |               |         |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |

## DIEPDMABN

DIEPDMABN is a DMA buffer address register for device IN endpoint *n*.

| Offset Address        |        |        |               |    |    |    |                    |    |    |    |    |    |    |    |    | Register Name |               |    |    |    |    |    |   | Total Reset Value |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-----------------------|--------|--------|---------------|----|----|----|--------------------|----|----|----|----|----|----|----|----|---------------|---------------|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0x091C + (0x0020 x n) |        |        |               |    |    |    |                    |    |    |    |    |    |    |    |    | DIEPDMABN     |               |    |    |    |    |    |   | 0x0000_0000       |   |   |   |   |   |   |   |   |   |   |   |   |   |
| (n = 0–15)            |        |        |               |    |    |    |                    |    |    |    |    |    |    |    |    |               |               |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Bit                   | 31     | 30     | 29            | 28 | 27 | 26 | 25                 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |   |   |   |
| Name                  |        |        |               |    |    |    |                    |    |    |    |    |    |    |    |    |               | DMABufferAddr |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset                 | 0      | 0      | 0             | 0  | 0  | 0  | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                       | Bits   | Access | Name          |    |    |    | Description        |    |    |    |    |    |    |    |    |               |               |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|                       | [31:0] | RO     | DMABufferAddr |    |    |    | DMA buffer address |    |    |    |    |    |    |    |    |               |               |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |   |   |   |   |   |   |



DOEPDMABN

**DOEPDMABN** is a DMA buffer address register for device OUT endpoint  $n$ .

DTXFSTS<sub>n</sub>

**DTXFSTS<sub>n</sub>** is a TX FIFO status register for device IN endpoints.

| Offset Address |          |                |    |    |                                                                                                                                                                                                                                                                              |    |    | Register Name |    |    |    |    |    |    |    | Total Reset Value |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------------|----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|-------------------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0938         |          |                |    |    |                                                                                                                                                                                                                                                                              |    |    | DTXFSTSn      |    |    |    |    |    |    |    | 0x0000_0000       |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29 | 28 | 27                                                                                                                                                                                                                                                                           | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                |    |    |                                                                                                                                                                                                                                                                              |    |    |               |    |    |    |    |    |    |    |                   | INEPTxFSpAvail |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0  | 0  | 0                                                                                                                                                                                                                                                                            | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0              | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name           |    |    | Description                                                                                                                                                                                                                                                                  |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | -        | reserved       |    |    | Reserved                                                                                                                                                                                                                                                                     |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RO       | INEPTxFSpAvail |    |    | Available space for the IN endpoint TX FIFO<br>0x0: The endpoint TX FIFO is full.<br>0x1: One word is available.<br>0x2: Two words are available.<br>0xn: $n$ words ( $0 \leq n \leq 32768$ ) are available.<br>0x8000: 32768 words are available.<br>Other values: reserved |    |    |               |    |    |    |    |    |    |    |                   |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## 11.8 USB 3.0 Host

### 11.8.1 Overview

The USB 3.0 module supports the 5 Gbit/s transfer rate defined in the USB 3.0 protocol and 480 Mbit/s transfer rate defined in the USB 2.0 protocol. It complies with the XHCI 1.0

protocol, PHY Interface for the PCI Express (PIPE) protocol (for super-speed transfer), and UTMI protocol (for high-speed transfer). It has an integrated root hub for extending the USB port or other hubs. The USB 3.0 module has the following functions:

- Controls and processes data transfer.
- Parses data packets and packages data.
- Encodes and decodes the signals transmitted over the USB port.
- Provides interfaces (such as the interrupt vector interface) for the driver.

## 11.8.2 Function Description

### Logic Block Diagram

[Figure 11-44](#) shows the logic block diagram of the USB 3.0 host controller.

**Figure 11-44** Logic block diagram of the USB 3.0 host



### Typical Applications

[Figure 11-45](#) shows the reference design of the USB 3.0 host.



## CAUTION

- The single-ended impedance of DP or DM is  $45\ \Omega \pm 1\%$ , and no extra matched resistors are required.
- The precision of the REXT resistor is  $\pm 1\%$ .
- If high-speed ESD components are used, 1 pF capacitors are recommended.

**Figure 11-45** USB 3.0 host reference design



## Functions

The USB 3.0 host controller has the following features:

- Complies with the USB 3.0, USB 2.0, USB 1.0, and XHCI 1.0 protocols.
- Independently works in host or device mode.
- Supports super-speed, high-speed, full-speed, and low-speed devices.
- Supports the USB 2.0 low-power solution and USB 3.0 power consumption states (U0, U1, U2, and U3).
- Supports control transfer, bulk transfer, isochronous transfer, and interrupt transfer in host mode.
- Supports control transfer, bulk transfer, and interrupt transfer in device mode.
- Supports the internal DMA controller.
- Supports a maximum of 127 devices by using USB hubs.

## Function Implementation

The USB 3.0 host supports the following four standard transfer modes:



- Control transfer

This mode applies to the data transfer between endpoints 0 of the USB host and USB device. For the USB devices of specific models, other endpoints may be used. The control transfer is bidirectional and the transferred data amount is small. Depending on the device and transfer speed, 8-byte data, 16-byte data, 32-byte data, or 64-byte data can be transferred.

- Bulk transfer

This mode is typically used when a large amount of data is transmitted or received with no requirements on the bandwidth and time interval. This mode is the best choice when the transfer speed is very low and many data transfers are delayed. Bulk transfer is performed after all other types of data transfers are complete. In bulk transfer mode, data is transmitted between the USB host and USB device without errors by using an error detection and retransmission mechanism.

- Isochronous transfer

This mode applies to the stream data transfer with strict time requirements and high error tolerance or the instant data transfer at a constant transfer rate. This mode provides a specific bandwidth and time interval.

- Interrupt transfer

This mode applies to transfer of small-sized, scattered, and unpredictable data. In this mode, the device is regularly checked for interrupt data to be sent. The query frequency ranges from 1 ms to 255 ms, which is determined by the device endpoint mode. Typically, the interrupt transfer is unidirectional and only input is available for the USB host.

## 11.8.3 Operating Mode

### Clock Reset

The clock and reset registers must be configured before the USB controller is initialized.

The working clock is disabled as follows:

**Step 1** Write 32'h31ff to PERI\_CRG44 to reset the USB controller.

**Step 2** Write 32'h501 to PERI\_CRG45 to configure the PHY.

**Step 3** Write 32'h1ff to PERI\_CRG44 to deassert the reset on the USB controller, and configure the clock of the USB controller.

----End

## 11.8.4 Register Variables

Table 11-16 describes the value range and meaning of the variables in the offset addresses for USB 3.0 registers.

**Table 11-16** Variables in the offset addresses for USB 3.0 registers

| Variable | Value Range |
|----------|-------------|
| e        | 0–31        |
| f        | 0–31        |



| Variable | Value Range |
|----------|-------------|
| p1       | 0–15        |
| p2       | 0–15        |

## 11.8.5 Register Summary

Table 11-17 describes USB 3.0 host registers.

**Table 11-17** Summary of USB 3.0 host registers (base address: 0xF98A\_0000)

| Offset Address     | Register                   | Description                               | Page                   |
|--------------------|----------------------------|-------------------------------------------|------------------------|
| 0xC100             | PERI_USB3_GSBUS_CFG0       | Global SoC bus configuration register 0   | <a href="#">11-183</a> |
| 0xC104             | PERI_USB3_GSBUS_CFG1       | Global SoC bus configuration register 1   | <a href="#">11-185</a> |
| 0xC108             | PERI_USB3_GTXT_HRCFG       | Global TX threshold control register      | <a href="#">11-186</a> |
| 0xC10C             | PERI_USB3_GRXT_HRCFG       | Global RX threshold control register      | <a href="#">11-186</a> |
| 0xC110             | PERI_USB3_GCTL             | Global core control register              | <a href="#">11-187</a> |
| 0xC118             | PERI_USB3_GSTS             | Global status register                    | <a href="#">11-191</a> |
| 0xC11C             | PERI_USB3_GUCTL_1          | Global user control register 1            | <a href="#">11-192</a> |
| 0xC120             | PERI_USB3_GSNPS_ID         | Global Synopsys ID register               | <a href="#">11-193</a> |
| 0xC124             | PERI_USB3_GGPIO            | Global GPIO register                      | <a href="#">11-193</a> |
| 0xC128             | PERI_USB3_GUID             | Global user ID register                   | <a href="#">11-193</a> |
| 0xC12C             | PERI_USB3_GUCTL            | Global user control register              | <a href="#">11-194</a> |
| 0xC130             | PERI_USB3_GBUSE_RRAADDR_LO | Global bus address error register         | <a href="#">11-195</a> |
| 0xC134             | PERI_USB3_GBUSE_RRAADD_HI  | Global bus address error register         | <a href="#">11-196</a> |
| 0xC200 + 0x04 x p1 | PERI_USB3_GUSB2_PHYCFGN    | Global USB 2.0 PHY configuration register | <a href="#">11-196</a> |
| 0xC2C0 + 0x04 x p2 | PERI_USB3_GUSB3_PIPECTLN   | Global USB 3.0 PIPE control register      | <a href="#">11-198</a> |
| 0xC300 + 0x04 x f  | PERI_USB3_GTXFI_FOSIZN     | Global TX FIFO size register              | <a href="#">11-201</a> |



| Offset Address    | Register                 | Description                                                   | Page                   |
|-------------------|--------------------------|---------------------------------------------------------------|------------------------|
| 0xC380 + 0x04 x f | PERI_USB3_GRXFI_FOSIZN   | Global RX FIFO size register                                  | <a href="#">11-202</a> |
| 0xC400 + 0x10 x e | PERI_USB3_GEVN_TADRN_LO  | Global event buffer address register                          | <a href="#">11-202</a> |
| 0xC404 + 0x10 x e | PERI_USB3_GEVN_TADRN_HI  | Global event buffer address register                          | <a href="#">11-202</a> |
| 0xC408 + 0x10 x e | PERI_USB3_GEVN_TSIZN     | Global event buffer size register                             | <a href="#">11-203</a> |
| 0xC40C + 0x10 x e | PERI_USB3_GEVN_TCOUNTN   | Global event buffer count register                            | <a href="#">11-203</a> |
| 0xC610            | PERI_USB3_GTXFI_FOPRIDEV | Peripheral global TX FIFO DMA priority register               | <a href="#">11-204</a> |
| 0xC618            | PERI_USB3_GTXFI_FOPRIHST | Host global TX FIFO DMA priority register                     | <a href="#">11-204</a> |
| 0xC61C            | PERI_USB3_GRXFI_FOPRIHST | Host global RX FIFO DMA priority register                     | <a href="#">11-205</a> |
| 0xC620            | PERI_USB3_GFIFO_PRIDBC   | Host global performance debug DMA priority register           | <a href="#">11-205</a> |
| 0xC624            | PERI_USB3_GDMA_HLRATIO   | High/Low priority ratio register for the host global FIFO DMA | <a href="#">11-206</a> |
| 0xC630            | PERI_USB3_GFLAD_J        | Global frame length adjustment register                       | <a href="#">11-207</a> |
| 0x0134            | PERI_USB5                | USB 3.0 system controller 0                                   | <a href="#">11-208</a> |
| 0x0138            | PERI_USB6                | USB 3.0 PCS system controller 1                               | <a href="#">11-209</a> |
| 0x013C            | PERI_USB7                | USB 3.0 PHY system controller 0                               | <a href="#">11-210</a> |
| 0x0140            | PERI_USB8                | USB 3.0 PHY system controller 1                               | <a href="#">11-211</a> |
| 0x0144            | PERI_USB9                | USB 3.0 PHY system controller 2                               | <a href="#">11-212</a> |
| 0x0148            | PERI_USB10               | USB 3.0 PHY system controller 3                               | <a href="#">11-214</a> |
| 0x014C            | PERI_USB12               | USB 3.0 system controller 3                                   | <a href="#">11-215</a> |

## 11.8.6 Register Description

### PERI\_USB3\_GSBUSCFG0

PERI\_USB3\_GSBUSCFG0 is global SoC bus configuration register 0.





|     |    |               |                                                                                    |
|-----|----|---------------|------------------------------------------------------------------------------------|
| [3] | RW | incr16brstena | 16-beat burst transfer enable for the AHB master INCR<br>0: disabled<br>1: enabled |
| [2] | RW | incr8brstena  | 8-beat burst transfer enable for the AHB master INCR<br>0: disabled<br>1: enabled  |
| [1] | RW | incr4brstena  | 4-beat burst transfer enable for the AHB master INCR<br>0: disabled<br>1: enabled  |
| [0] | RW | incrbrstena   | 1-beat burst transfer enable for the AHB master INCR<br>0: disabled<br>1: enabled  |

## PERI\_USB3\_GSBUSCFG1

PERI\_USB3\_GSBUSCFG1 is global SoC bus configuration register 1.

|         | Offset Address<br>0xC104 |                |    |                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GSBUSCFG1 |                |    |          |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |
|---------|--------------------------|----------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|----------------|----|----------|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|
| Bit     | 31                       | 30             | 29 | 28                                                                                                                                              | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                                   | 14             | 13 | 12       | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved                 |                |    |                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |    | en1kpage                             | pipetranslimit |    | reserved |    |    |   |   |                                  |   |   |   |   |   |   |   |
| Reset   | 0                        | 0              | 0  | 0                                                                                                                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                    | 0              | 0  | 0        | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits    | Access                   | Name           |    | Description                                                                                                                                     |    |    |    |    |    |    |    |    |    |    |    |    |                                      |                |    |          |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [31:13] | RW                       | reserved       |    | Reserved                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                                      |                |    |          |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [12]    | RW                       | en1kpage       |    | Boundary select<br>0: 4 KB boundary<br>1: 1 KB boundary                                                                                         |    |    |    |    |    |    |    |    |    |    |    |    |                                      |                |    |          |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [11:8]  | RW                       | pipetranslimit |    | Number of AXI master outstanding requests<br>0x0: 1 request<br>0x1: 2 requests<br>0x2: 3 requests<br>0x3: 4 requests<br>...<br>0xF: 16 requests |    |    |    |    |    |    |    |    |    |    |    |    |                                      |                |    |          |    |    |   |   |                                  |   |   |   |   |   |   |   |
| [7:0]   | -                        | reserved       |    | Reserved                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                                      |                |    |          |    |    |   |   |                                  |   |   |   |   |   |   |   |



## PERI\_USB3\_GTXTHRCFG

PERI\_USB3\_GTXTHRCFG is a global TX threshold control register.

| Bit     | Offset Address |                   |                |                                                                                                                                                                                                                                                                                           |             |                   |    |    | Register Name       |    |    |    |    |          |    |    | Total Reset Value |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------|----|----|---------------------|----|----|----|----|----------|----|----|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|         | 0xC108         |                   |                |                                                                                                                                                                                                                                                                                           |             |                   |    |    | PERI_USB3_GTXTHRCFG |    |    |    |    |          |    |    | 0x0000_0000       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Name    | 31             | 30                | 29             | 28                                                                                                                                                                                                                                                                                        | 27          | 26                | 25 | 24 | 23                  | 22 | 21 | 20 | 19 | 18       | 17 | 16 | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|         | reserved       |                   | usbtxpktcntsel | reserved                                                                                                                                                                                                                                                                                  | usbtxpktcnt | usbmaxtxburstsize |    |    |                     |    |    |    |    | reserved |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset   | 0              | 0                 | 0              | 0                                                                                                                                                                                                                                                                                         | 0           | 0                 | 0  | 0  | 0                   | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits    | Access         | Name              |                | Description                                                                                                                                                                                                                                                                               |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:30] | -              | reserved          |                | Reserved                                                                                                                                                                                                                                                                                  |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [29]    | RW             | usbtxpktcntsel    |                | USB TX FIFO threshold select. This field is valid only in super-speed mode.<br>0: The USB module starts data transfer only after all packets are read to the specified TX FIFO.<br>1: The USB module starts data transfer only after specified packets are read to the specified TX FIFO. |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [28]    | -              | reserved          |                | Reserved                                                                                                                                                                                                                                                                                  |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [27:24] | RW             | usbtxpktcnt       |                | TX FIFO threshold. The value range is 1–15.                                                                                                                                                                                                                                               |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [23:16] | RW             | usbmaxtxburstsize |                | Maximum TX burst size. This field is valid only for the OUT endpoint during bulk transfer, isochronous transfer, or interrupt transfer at a super speed in host mode. The value range is 1–16.                                                                                            |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]  | -              | reserved          |                | Reserved                                                                                                                                                                                                                                                                                  |             |                   |    |    |                     |    |    |    |    |          |    |    |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## PERI\_USB3\_GRXTHRCFG

PERI\_USB3\_GRXTHRCFG is a global RX threshold control register.



| Offset Address |          |                |          |                   |                   |          |    | Register Name                                                                                                                                                                                                                                                                             |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------------|----------|-------------------|-------------------|----------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0xC10C         |          |                |          |                   |                   |          |    | PERI_USB3_GRXTHRCFG                                                                                                                                                                                                                                                                       |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30             | 29       | 28                | 27                | 26       | 25 | 24                                                                                                                                                                                                                                                                                        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved | usbtxpktcntsel | reserved | usbttxpktcnt      | usbmaxtxburstsize | reserved |    |                                                                                                                                                                                                                                                                                           |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0              | 0        | 0                 | 0                 | 0        | 0  | 0                                                                                                                                                                                                                                                                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           |          | Access         |          | Name              |                   |          |    | Description                                                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:30]        |          | -              |          | reserved          |                   |          |    | Reserved                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [29]           |          | RW             |          | usbttxpktcntsel   |                   |          |    | USB RX FIFO threshold select. This field is valid only in super-speed mode.<br>0: The USB module starts data transfer only after all packets are read to the specified RX FIFO.<br>1: The USB module starts data transfer only after specified packets are read to the specified RX FIFO. |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [28]           |          | -              |          | reserved          |                   |          |    | Reserved                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [27:24]        |          | RW             |          | usbttxpktcnt      |                   |          |    | RX FIFO threshold. The value range is 1–15.                                                                                                                                                                                                                                               |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [23:19]        |          | RW             |          | usbmaxtxburstsize |                   |          |    | Reserved                                                                                                                                                                                                                                                                                  |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [18:0]         |          | -              |          | reserved          |                   |          |    | Maximum RX burst size. This field is valid only for the IN endpoint during bulk transfer, isochronous transfer, or interrupt transfer at a super speed in host mode. The value range is 1–16.                                                                                             |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

PERI\_USB3\_GCTL

PERI\_USB3\_GCTL is a global core control register.



| Offset Address |            |                  |                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    | Register Name  |                  |             |          |          |           |               |            |                |             |           |           | Total Reset Value |             |                  |             |   |   |   |   |   |  |  |  |
|----------------|------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----------------|------------------|-------------|----------|----------|-----------|---------------|------------|----------------|-------------|-----------|-----------|-------------------|-------------|------------------|-------------|---|---|---|---|---|--|--|--|
| 0xC110         |            |                  |                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    | PERI_USB3_GCTL |                  |             |          |          |           |               |            |                |             |           |           | 0x0000_0000       |             |                  |             |   |   |   |   |   |  |  |  |
| Bit            | 31         | 30               | 29                                                                                                                                                                                                                                                                                  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20             | 19               | 18          | 17       | 16       | 15        | 14            | 13         | 12             | 11          | 10        | 9         | 8                 | 7           | 6                | 5           | 4 | 3 | 2 | 1 | 0 |  |  |  |
| Name           | pwrdnscale |                  |                                                                                                                                                                                                                                                                                     |    |    |    |    |    |    |    |    |                | masterfiltbypass | bypssetaddr | u2rstecn | firmsdwn | prtcapdir | coresoftreset | softipsync | ul12timerscale | debugattach | ramelkSEL | scaledown | disscramble       | u2exit_1fps | gbllibernationen | dsblclkting |   |   |   |   |   |  |  |  |
| Reset          | 0          | 0                | 0                                                                                                                                                                                                                                                                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0                | 0           | 0        | 0        | 0         | 0             | 0          | 0              | 0           | 0         | 0         | 0                 | 0           | 0                | 0           | 0 | 0 | 0 |   |   |  |  |  |
| Bits           | Access     | Name             | Description                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |                |                  |             |          |          |           |               |            |                |             |           |           |                   |             |                  |             |   |   |   |   |   |  |  |  |
| [31:19]        | RW         | pwrdnscale       | Suspend_clk<br>GCTL[31:19] x 16 k = Suspend_clk<br>Note: 32 kHz < Suspend_clk < 125 MHz                                                                                                                                                                                             |    |    |    |    |    |    |    |    |                |                  |             |          |          |           |               |            |                |             |           |           |                   |             |                  |             |   |   |   |   |   |  |  |  |
| [18]           | RW         | masterfiltbypass | Filtering select<br>0: Filtering is enabled when DWC_USB3_EN_BUS_FILTERS is 1.<br>1: Filtering is disabled regardless of the value of DWC_USB3_EN_BUS_FILTERS.                                                                                                                      |    |    |    |    |    |    |    |    |                |                  |             |          |          |           |               |            |                |             |           |           |                   |             |                  |             |   |   |   |   |   |  |  |  |
| [17]           | RW         | bypssetaddr      | SetAddress command in device mode<br>0: The host sends the SetAddress command to the device.<br>1: The host does not send the SetAddress command to the device. The device reads the value of DCFG[DevAddress] as the address value.<br>This bit is configured only for simulation. |    |    |    |    |    |    |    |    |                |                  |             |          |          |           |               |            |                |             |           |           |                   |             |                  |             |   |   |   |   |   |  |  |  |
| [16]           | RW         | u2rstecn         | Super-speed connection<br>0: When the super-speed connection fails, the device is in high-speed mode.<br>1: When the super-speed connection fails, the device waits for more than three cycles.<br>This bit is valid only in device mode.                                           |    |    |    |    |    |    |    |    |                |                  |             |          |          |           |               |            |                |             |           |           |                   |             |                  |             |   |   |   |   |   |  |  |  |



|         |    |               |                                                                                                                                                                                                                                                                                                                                                                           |
|---------|----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:14] | RW | frmscldwn     | SOF/USOF/ITP interval in super-speed or high-speed mode<br>0x3: 15.625 µs<br>0x2: 31.25 µs<br>0x1: 62.5 µs<br>0x1: 125 µs<br>The corresponding value needs to be multiplied by 8 in full-speed mode.<br>Maximum packet size of bulk in or bulk out transfer during simulation in xHCI debug mode<br>0x0: 1024 bytes<br>0x1: 512 bytes<br>0x2: 256 bytes<br>0x3: 128 bytes |
| [13:12] | RW | prtcapdir     | Port function configuration<br>01: host<br>10: device<br>11: OTG<br>00: reserved                                                                                                                                                                                                                                                                                          |
| [11]    | RW | coresoftreset | Core soft reset select<br>0: not reset<br>1: soft reset<br>Note: When the core is soft-reset, all interrupts excluding the interrupts of the following registers are cleared:<br>-GCTL<br>-GUCTL<br>-GSTS<br>-GSNPSID<br>-GGPIO<br>-GUID<br>-GUSB2PHYCFGn<br>-GUSB3PIPECTLn<br>-DCFG<br>-DCTL<br>-DEVTEN<br>-DSTS                                                         |
| [10]    | RW | sofitpsync    | 0: The first port of the UTMI/ULPI PHY is not suspended no matter whether other SS ports are in the Rx.Detect, SS.Disable, or U3 state.<br>1: The first port of the UTMI/ULPI PHY is not suspended no matter whether other non-SS ports are suspended.<br>Note: This field is valid only when the USB controller is in host mode.                                         |



|       |    |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9]   | RW | u1u2timerscale | U1/U2 timer scale-down enable<br>0: enabled<br>1: disabled when GCTL bit[5:4] (ScaleDown) is X1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [8]   | RW | debugattach    | Debug<br>When this field is set to 1:<br>After the Ru/Stop bit in the DCTL register is set to 1, the SS controller enters the polling link state without detecting the connection of the remote device.<br>The timeout period for link LFPS polling is limited.<br>The timeout period for TS1 polling is limited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [7:6] | RW | ramclksel      | RAM clock select<br>00: bus clock<br>01: pipe clock<br>10: pipe/2 clock<br>11: reserved<br>Note: In host mode, hardware sets this field to 00 (the ram_clk connects to the bus_clk). Therefore, when the SS port is in P3 state, the PIPE clock is disabled, and the USB 2.0 port does not work.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [5:4] | RW | scaledown      | Scale-down timing select<br>In high-speed, full-speed, or low-speed mode:<br>00: All scale-down timings are disabled, and the actual timings are used for simulation.<br>01: All scale-down timings excluding the timings related to the following functions are enabled:<br>-Speed enumeration<br>-HNP/SRP<br>-Suspend and resume in host mode<br>10: Only the scale-down timings related to the suspend and resume functions in device mode are enabled.<br>11: All scale-down timings are enabled.<br>For the SS mode:<br>00: All scale-down timings are disabled, and the actual timings are used for simulation.<br>01: The SS scale-down timings are enabled, including:<br>-The number of TxEq training sequences is decreased to 8.<br>-The LFPS polling burst time is reduced to 100 ns.<br>-The LFPS warm reset receive is reduced to 30 $\mu$ s.<br>10: TxEq training sequences are not transmitted.<br>11: All scale-down timings are enabled. |



|     |    |                  |                                                                                                                                                                                               |
|-----|----|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3] | RW | disscramble      | Scrambling enable<br>1: disabled<br>0: enabled                                                                                                                                                |
| [2] | RW | u2exit_lfps      | U2 state exit signal<br>0: The link layer considers the 248 ns LFPS signal as an active U2 state exit signal.<br>1: The link layer waits 8 µs after detecting an active U2 state exit signal. |
| [1] | RW | gblhibernationen | Global hibernation enable<br>0: disabled. When the PMU accepts status switching between D0 and D3, the internal status of the core is not retained or restored.<br>1: enabled                 |
| [0] | RW | dsblclkgtng      | Internal clock gating enable<br>0: enabled<br>1: disabled when the core is in LPM mode<br>Note: This field can be set to 1 after power-on reset.                                              |

## PERI\_USB3\_GSTS

PERI\_USB3\_GSTS is a global status register.

|         | Offset Address<br>0xC118 |          |    |                                                                                                                                           |    |    |    |    |    |    | Register Name<br>PERI_USB3_GSTS |    |    |    |    |    |    |    |    |    | Total Reset Value<br>0x0000_0000 |       |        |         |           |             |               |          |          |        |   |   |
|---------|--------------------------|----------|----|-------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|---------------------------------|----|----|----|----|----|----|----|----|----|----------------------------------|-------|--------|---------|-----------|-------------|---------------|----------|----------|--------|---|---|
| Bit     | 31                       | 30       | 29 | 28                                                                                                                                        | 27 | 26 | 25 | 24 | 23 | 22 | 21                              | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11                               | 10    | 9      | 8       | 7         | 6           | 5             | 4        | 3        | 2      | 1 | 0 |
| Name    | cbelt                    |          |    |                                                                                                                                           |    |    |    |    |    |    | reserved                        |    |    |    |    |    |    |    |    |    | otg_ip                           | bc_ip | adp_ip | host_ip | device_ip | crsttimeout | buserraddrvid | reserved | reserved | curmod |   |   |
| Reset   | 0                        | 0        | 0  | 0                                                                                                                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                | 0     | 0      | 0       | 0         | 0           | 0             | 0        | 0        | 0      |   |   |
| Bits    | Access                   | Name     |    | Description                                                                                                                               |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |                                  |       |        |         |           |             |               |          |          |        |   |   |
| [31:20] | RO                       | cbelt    |    | Minimum value among all received device BELT values and the BELT value configured by the Set Latency Tolerance Value command in host mode |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |                                  |       |        |         |           |             |               |          |          |        |   |   |
| [19:11] | -                        | reserved |    | Reserved                                                                                                                                  |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |                                  |       |        |         |           |             |               |          |          |        |   |   |
| [10]    | RO                       | otg_ip   |    | An OTG-related interrupt in the OEVT register is waiting for handling.                                                                    |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |                                  |       |        |         |           |             |               |          |          |        |   |   |
| [9]     | RO                       | bc_ip    |    | A BC-related interrupt in the BCEVT register is waiting for handling.                                                                     |    |    |    |    |    |    |                                 |    |    |    |    |    |    |    |    |    |                                  |       |        |         |           |             |               |          |          |        |   |   |



|       |    |               |                                                                                                          |
|-------|----|---------------|----------------------------------------------------------------------------------------------------------|
| [8]   | RO | adp_ip        | An ADP-related interrupt in the ADPEVT register is waiting for handling.                                 |
| [7]   | RO | host_ip       | An xHCI-related interrupt in the host event queue is waiting for handling.                               |
| [6]   | RO | device_ip     | An xHCI-related interrupt in the device event queue is waiting for handling.                             |
| [5]   | RO | csrttimeout   | The duration of accessing registers by software exceeds the time defined by DWC_USB3_CSR_ACCESS_TIMEOUT. |
| [4]   | RO | buserraddrvld | GBUSERRADDR register validity indicator and start address for the error position.                        |
| [3:2] | -  | reserved      | Reserved                                                                                                 |
| [1:0] | RO | curmod        | Current working mode<br>00: device mode<br>01: host mode                                                 |

PERI\_USB3\_GUCTL1

PERI USB3 GUCTL1 is global user control register 1.



## PERI\_USB3\_GSNPSID

**PERI\_USB3\_GSNPSID** is a Synopsys ID register.

| Offset Address |            |            |    |    |                                                                           |    |    | Register Name     |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|------------|------------|----|----|---------------------------------------------------------------------------|----|----|-------------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0xC120         |            |            |    |    |                                                                           |    |    | PERI_USB3_GSNPSID |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31         | 30         | 29 | 28 | 27                                                                        | 26 | 25 | 24                | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | synopsysid |            |    |    |                                                                           |    |    |                   |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0          | 0          | 0  | 0  | 0                                                                         | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access     | Name       |    |    | Description                                                               |    |    |                   |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RO         | synopsysid |    |    | The upper 16 bits indicate USB 3.0, and the lower 16 bits indicate 2.50a. |    |    |                   |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## PERI\_USB3\_GGPIO

PERI\_USB3\_GGPIO is a global GPIO register.

| Offset Address |      |        |      |    |                           |             |    | Register Name   |    |    |    |    |     |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|------|--------|------|----|---------------------------|-------------|----|-----------------|----|----|----|----|-----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0xC124         |      |        |      |    |                           |             |    | PERI_USB3_GGPIO |    |    |    |    |     |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31   | 30     | 29   | 28 | 27                        | 26          | 25 | 24              | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | gpo  |        |      |    |                           |             |    |                 |    |    |    |    | gpi |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0    | 0      | 0    | 0  | 0                         | 0           | 0  | 0               | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
|                | Bits | Access | Name |    |                           | Description |    |                 |    |    |    |    |     |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW   | gpo    |      |    | Drive value of gp_o[15:0] |             |    |                 |    |    |    |    |     |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RO   | gpi    |      |    | Read value of gp_i[15:0]  |             |    |                 |    |    |    |    |     |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

## PERI USB3 GUID

PERI USB3 GUID is a global user ID register.

| Offset Address |          |          |    |    |    |                                                                          |    | Register Name  |    |    |    |    |    |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|----------|----|----|----|--------------------------------------------------------------------------|----|----------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0xC128         |          |          |    |    |    |                                                                          |    | PERI_USB3_GUID |    |    |    |    |    |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30       | 29 | 28 | 27 | 26                                                                       | 25 | 24             | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |          |    |    |    |                                                                          |    |                |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0  | 0                                                                        | 0  | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name     |    |    |    | Description                                                              |    |                |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:0]         | RO       | reserved |    |    |    | User information including the system version and hardware configuration |    |                |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



PERI\_USB3\_GUCL

**PERI\_USB3\_GUCTL** is a global user control register.



|        |    |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14]   | RW | usbhstlnautoretryen | Automatic retransmission enable for host inputs<br>0: disabled<br>If an error occurs during host input transfer, the host automatically replies an ACK indicating termination to the device (Retry = 1 and NumP = 0).<br>1: enabled<br>If automatic retransmission is enabled and an error occurs during host input transfer, the host automatically replies an ACK not indicating termination to the device (Retry = 1 and NumP != 0). |
| [13]   | RW | enoverlapchk        | LFPS overlap signal detection enable<br>1: The LFPS overlap signal is detected to avoid glitches.<br>0: The LFPS overlap signal is not detected.                                                                                                                                                                                                                                                                                        |
| [12]   | RW | extcapsupten        | External additional function enable<br>1: enabled<br>0: disabled                                                                                                                                                                                                                                                                                                                                                                        |
| [11]   | RW | csr                 | Extra delay inserted between full-speed BULKOUT transfers                                                                                                                                                                                                                                                                                                                                                                               |
| [10:9] | RW | dtct                | Rough timeout period that the device responds to the host. If this field is set to 0, the timeout period is defined by the DTFT; if this field is not 0, the timeout period is as follows:<br>01: 500 µs<br>10: 1.5 ms<br>11: 6.5 ms                                                                                                                                                                                                    |
| [8:0]  | RW | dtft                | Exact timeout period that the device responds to the host. This field is valid when the DTCT is 0.<br>$T = DTFT \times 256 \times 8 \mu s$                                                                                                                                                                                                                                                                                              |

## PERI\_USB3\_GBUSERRADDR\_LO

PERI\_USB3\_GBUSERRADDR\_LO is a global bus address error register.

|        | Offset Address |           |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name            |    |    |    |    |    |   |   | Total Reset Value |   |   |   |   |   |   |   |
|--------|----------------|-----------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|----|----|---|---|-------------------|---|---|---|---|---|---|---|
|        | 0xC130         |           |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    | PERI_USB3_GBUSERRADDR_LO |    |    |    |    |    |   |   | 0x0000_0000       |   |   |   |   |   |   |   |
| Bit    | 31             | 30        | 29 | 28                                                                                                                                                                                                 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | busaddrlo      |           |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| Reset  | 0              | 0         | 0  | 0                                                                                                                                                                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 |   |
| Bits   | Access         | Name      |    | Description                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |
| [31:0] | RO             | busaddrlo |    | Lower 32 bits of the error address<br>This field is valid only when GSTS[BusErrAddrVld] is 1.<br>This field is cleared only during reset, and it supports only the AHB and AXI bus configurations. |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |    |    |   |   |                   |   |   |   |   |   |   |   |



## PERI\_USB3\_GBUSERRADD\_HI

PERI\_USB3\_GBUSERRADD\_HI is a global bus address error register.

|        | Offset Address |           |    |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    | Register Name           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |
|--------|----------------|-----------|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|
|        | 0xC134         |           |    |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    | PERI_USB3_GBUSERRADD_HI |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |
| Bit    | 31             | 30        | 29 | 28 | 27                                                                                                                                                                                                 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |
| Name   | busaddrhi      |           |    |    |                                                                                                                                                                                                    |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |
| Reset  | 0              | 0         | 0  | 0  | 0                                                                                                                                                                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |
| Bits   | Access         | Name      |    |    | Description                                                                                                                                                                                        |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |
| [31:0] | RO             | busaddrhi |    |    | Upper 32 bits of the error address<br>This field is valid only when GSTS[BusErrAddrVld] is 1.<br>This field is cleared only during reset, and it supports only the AHB and AXI bus configurations. |    |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |

## PERI\_USB3\_GUSB2PHYCFGN

PERI\_USB3\_GUSB2PHYCFGN is a global USB 2.0 PHY configuration register.

|       | Offset Address                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |    |    |                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    | Register Name          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | Total Reset Value |   |   |   |   |  |  |  |  |  |  |  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------------|---|---|---|---|--|--|--|--|--|--|--|
|       | 0xC200 + 0x04 x p1                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |    |    |                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    | PERI_USB3_GUSB2PHYCFGN |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0x0000_0000       |   |   |   |   |  |  |  |  |  |  |  |
| Bit   | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 30           | 29 | 28 | 27                                                                                                                                                                                                                                                                                                                      | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |   |   |   |   |  |  |  |  |  |  |  |
| Name  | phy_soft_rst <ul style="list-style-type: none"><li>phy_freeclk_exists</li><li>ulpi_lpnm_with_opmode_chk</li></ul> reserved <ul style="list-style-type: none"><li>ulpi_ext_vbus_indicator</li><li>ulpi_ext_vbus_drv</li><li>reserved</li><li>ulpi_auto_res</li><li>reserved</li></ul> usbtrdtim <ul style="list-style-type: none"><li>xcvrdly</li><li>enblslpm</li><li>physel</li><li>susphy</li><li>fsintf</li><li>ulpi_utmi_sel</li><li>phyif</li><li>toutcal</li></ul> |              |    |    |                                                                                                                                                                                                                                                                                                                         |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |
| Reset | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0            | 0  | 0  | 0                                                                                                                                                                                                                                                                                                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |
| Bits  | Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Name         |    |    | Description                                                                                                                                                                                                                                                                                                             |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |
| [31]  | RW                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | phy_soft_rst |    |    | UTMI PHY reset by triggering the usb2phy_reset signal<br>In this case, the ULPI PHY is not reset, because it is reset by configuring the FunctionControl[Reset] register. When the core is reset, the core automatically configures vcc_reset_n, USBCMD[HCRST], DCTL[SoftReset], or GCTL[SoftReset] to implement reset. |    |    |    |    |    |    |    |    |    |    |    |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                   |   |   |   |   |  |  |  |  |  |  |  |



|         |    |                           |                                                                                                                                                                                                                                    |
|---------|----|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [30]    | RW | u2_freeclk_exists         | Whether the USB 2.0 PHY provides the free_clk<br>0: no<br>1: yes                                                                                                                                                                   |
| [29]    | RW | ulp1_lpm_with_op_mode_chk | NOPID TX enable of the ULPI PHY in LPM mode<br>0: In LPM mode, the controller transmits NOPID before transmitting EXTPID.<br>1: In LPM mode, the controller does not transmit NOPID before transmitting EXTPID.                    |
| [28:19] | RW | reserved                  | Reserved                                                                                                                                                                                                                           |
| [18]    | RW | ulp1_ext_vbus_indicator   | ULPI external Vbus indicator<br>0: The PHY uses the internal Vbus valid comparator.<br>1: The PHY uses the external Vbus valid comparator.                                                                                         |
| [17]    | RW | ulp1_ext_vbus_drv         | ULPI external Vbus indicator<br>0: The PHY uses the internal Vbus valid comparator.<br>1: The PHY uses the external Vbus valid comparator.                                                                                         |
| [16]    | RW | reserved                  | Reserved                                                                                                                                                                                                                           |
| [15]    | RW | ulp1_auto_res             | ULPI automatic resume enable<br>0: disabled<br>1: enabled                                                                                                                                                                          |
| [14]    | RW | reserved                  | Reserved                                                                                                                                                                                                                           |
| [13:10] | RW | usbtrdtim                 | USB 2 turnaround time, that is, response time after the MAC requests the packet FIFO controller (PFC) to fetch data from the DFIFO (SPRAM)<br>0x5 for the 16-bit UTMI+ interface<br>0x9 for the 8-bit UTMI+ or ULPI interface      |
| [9]     | RW | xcvrdly                   | TX/RX delay. When this field is set to 1, the 2.5 $\mu$ s delay is added between the time when Transceiver Select is set to 00 (high speed) and the time when TxValid is 0 to transmit the chirp-K handshake signal.               |
| [8]     | RW | enblslpm                  | Whether the utmi_sleep_n and utmi_11_suspend_n signals connect to the PHY<br>0: The utmi_sleep_n and utmi_11_suspend_n signals do not connect to the PHY.<br>1: The utmi_sleep_n and utmi_11_suspend_n signals connect to the PHY. |
| [7]     | RW | physel                    | PHY interface type<br>0: USB 2.0 high-speed UTMI+ or ULPI PHY interface<br>1: USB 1.1 full-speed serial interface<br>This bit is set to 1 when it is write-only.                                                                   |



|       |    |               |                                                                                                                                                                                                                                                                                                                                                   |
|-------|----|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]   | RW | susphy        | USB 2.0 high-speed/full-speed/low-speed PHY suspend<br>0: not suspended<br>1: suspended<br>Note: In host mode, set this field to 1 after the core is initialized.                                                                                                                                                                                 |
| [5]   | RW | fsintf        | Type of the full-speed PHY interface<br>0: 6-pin unidirectional full-speed serial transfer interface<br>1: 3-pin bidirectional full-speed serial transfer interface<br>When this bit is read-only, the return value is 0.                                                                                                                         |
| [4]   | RW | ulpi_utmi_sel | Type of the high-speed PHY interface<br>0: UTMI+<br>1: ULPI                                                                                                                                                                                                                                                                                       |
| [3]   | RW | phyif         | Data width of the UTMI interface<br>0: 8 bits<br>1: 16 bits                                                                                                                                                                                                                                                                                       |
| [2:0] | RW | toutcal       | High-speed/Full-speed timeout calibration<br>The corresponding bit time is added to each PHY clock.<br>High-speed mode:<br>One 30 MHz PHY clock = 16 bit times<br>One 60 MHz PHY clock = 8 bit times<br>Full-speed mode:<br>One 30 MHz PHY clock = 0.4 bit times<br>One 60 MHz PHY clock = 0.2 bit times<br>One 48 MHz PHY clock = 0.25 bit times |

## PERI\_USB3\_GUSB3PIPECTLN

PERI\_USB3\_GUSB3PIPECTLN is a global USB 3.0 PIPE control register.



| Offset Address<br>0xC2C0 + 0x04 x p2<br>(p2 = 0-15) |              |                       |               |                                                                                                                                                                                                                                                                                                                                                               |               |                     |                       |                |          |          |          |            |                       |            |          | Register Name<br>PERI_USB3_GUSB3PIPECTLN |           |               |              |           |             |                      |          | Total Reset Value<br>0x0000_0000 |          |              |                     |   |   |   |   |   |
|-----------------------------------------------------|--------------|-----------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------|-----------------------|----------------|----------|----------|----------|------------|-----------------------|------------|----------|------------------------------------------|-----------|---------------|--------------|-----------|-------------|----------------------|----------|----------------------------------|----------|--------------|---------------------|---|---|---|---|---|
| Bit                                                 | 31           | 30                    | 29            | 28                                                                                                                                                                                                                                                                                                                                                            | 27            | 26                  | 25                    | 24             | 23       | 22       | 21       | 20         | 19                    | 18         | 17       | 16                                       | 15        | 14            | 13           | 12        | 11          | 10                   | 9        | 8                                | 7        | 6            | 5                   | 4 | 3 | 2 | 1 | 0 |
| Name                                                | phy_soft_rst | hstprtcmpl            | u2ssinactp3ok | disrxdetp3                                                                                                                                                                                                                                                                                                                                                    | ux_exit_in_px | ping_enhancement_en | u1u2exitfail_to_recov | request_p1p2p3 | reserved | reserved | reserved | delaylp2p3 | delay phy powerchange | suspend_en | datwidth | abortrxdefini2                           | skiprxdet | lfps_p0_align | p3p2_tran_ok | p3exsigp2 | lfps_filter | polling_lfps_control | reserved | txswing                          | txmargin | txdeemphasis | elastic_buffer_mode |   |   |   |   |   |
| Reset                                               | 0            | 0                     | 0             | 0                                                                                                                                                                                                                                                                                                                                                             | 0             | 0                   | 0                     | 0              | 0        | 0        | 0        | 0          | 0                     | 0          | 0        | 0                                        | 0         | 0             | 0            | 0         | 0           | 0                    | 0        | 0                                | 0        | 0            | 0                   | 0 | 0 | 0 |   |   |
| Bits                                                | Access       | Name                  |               | Description                                                                                                                                                                                                                                                                                                                                                   |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [31]                                                | RW           | phy_soft_rst          |               | USB 3.0 soft reset                                                                                                                                                                                                                                                                                                                                            |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [30]                                                | RW           | hstprtcmpl            |               | PIPE PHY template test without the USB 3.0 cable                                                                                                                                                                                                                                                                                                              |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [29]                                                | RW           | u2ssinactp3ok         |               | PHY state select in U2/SSInactive state<br>0: The PHY enters the P2 state.<br>1: The PHY enters the P3 state.                                                                                                                                                                                                                                                 |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [28]                                                | RW           | disrxdetp3            |               | RX detection enable in P3 state<br>0: If the PHY is in P3 state and the core requires RX detection, the core performs RX detection in P3 state.<br>1: If the PHY is in P3 state and the core requires RX detection, the core switches the PHY state to P2 and then performs RX detection. After detection is complete, the core switches the PHY state to P3. |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [27]                                                | RW           | ux_exit_in_px         |               | PHY state select when the core state is switched<br>0: The PHY is in P0 state when the core exits the U1, U2, or U3 state.<br>0: The PHY is in P1, P2, or P3 state when the core exits the U1, U2, or U3 state respectively.<br>Note: Set this field to 0 when the Synopsys PHY is used.                                                                      |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [26]                                                | RW           | ping_enhancement_en   |               | Timeout period changed from 500 ms to 300 ms for the ping command of the downlink port U1<br>Note: Set this field to 0 when the Synopsys PHY is used.                                                                                                                                                                                                         |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |
| [25]                                                | RW           | u1u2exitfail_to_recov |               | When this bit is set to 1, and U1/U2 LFPS handshake fails, the LTSSM transitions from the U1/U2 state to Recovery state instead of SS Inactive state. If Recovery fails, then the LTSSM can enter the SS Inactive state. This is an enhancement only. It prevents interoperability issues if the remote link does not do proper handshake.                    |               |                     |                       |                |          |          |          |            |                       |            |          |                                          |           |               |              |           |             |                      |          |                                  |          |              |                     |   |   |   |   |   |



|         |    |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|----|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [24]    | RW | request_p1p2p3        | When the core state is switched from U0 to U1, U2, or U3, the core always requests the PHY to switch the state from P0 to P1, P2, or P3 respectively.<br>Note: Set this field to 1 when the Synopsys PHY is used.                                                                                                                                                                                                                                           |
| [23]    | RW | reserved              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [22]    | RW | reserved              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [21:19] | RW | delayp1p2p3           | Delay when the state is switched from P0 to P1, P2, or P3<br>When the core enters the U1, U2, or U3 status, the time when the P0 state is switched to P1, P2, or P3 is prolonged until Pipe3_RxValid is set to 0 or an 8B10B error occurs.<br>Note: This function is valid only when bit 18 is set to 1.                                                                                                                                                    |
| [18]    | RW | delay_phy_powerchange | PHY status switch delay<br>0: When the core state is switched from U0 to U1, U2, or U3, the time when the PHY enters the P1, P2, or P3 state is delayed until the values of Pipe3_RxElecIdle and pipe3_RxValid are 0.<br>0: When the core state is switched from U0 to U1, U2, or U3, the PHY enters the P1, P2, or P3 state without querying the values of Pipe3_RxElecIdle and pipe3_RxValid.<br>Note: Set this field to 1 when the Synopsys PHY is used. |
| [17]    | RW | suspend_en            | USB 3.0 PHY suspend enable<br>0: not suspended<br>1: suspended<br>Note: In host mode, set this field to 1 after the core is initialized.                                                                                                                                                                                                                                                                                                                    |
| [16:15] | RW | datwidth              | Data width of the PIPE interface<br>00: 32 bits<br>01: 16 bits<br>10: 8 bits<br>11: reserved                                                                                                                                                                                                                                                                                                                                                                |
| [14]    | RW | abortrxdetinu2        | RX detection abort in U2 state<br>When this field is set to 1 and the connection state is U2, the core receives a U2 state exit signal from a remote device and RX detection is not performed.<br>Note: Set this field to 0 when the Synopsys PHY is used.                                                                                                                                                                                                  |
| [13]    | RW | skiprxdet             | RX detection skip. When this field is set to 1, RX detection is skipped if pipe3_RxElecIdle is pulled down.                                                                                                                                                                                                                                                                                                                                                 |
| [12]    | RW | lfps_p0_align         | When the controller exits the U1, U2, or U3 state, LFPS signal transfer is stopped at the clock edge of the PHY P0 state request signal. Otherwise, the LFPS signal is transmitted one cycle earlier.<br>When the PHY state is switched from P1 or P2 to P0, the controller requests data transfer two clock cycles later after the PHY sets PhyStatus.                                                                                                     |



|       |    |                      |                                                                                                                                                                                                                                                                                                   |
|-------|----|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11]  | RW | p3p2_tran_ok         | P2/P3 state switch<br>1: The PHY is switched from P2 to P3 or from P3 to P2 without entering the intermediate status P0.<br>0: The PHY enters the intermediate status P0 each time when the PHY status is switched between P2 and P3.<br>Note: Set this field to 0 when the Synopsys PHY is used. |
| [10]  | RW | p3exsigp2            | P3 exit status select<br>1: When the core exits the U3 state, the PHY state must be switched from P3 to P2.<br>0: When the core exits the U3 state, the PHY state can be switched from P3 to other state.<br>Note: Set this field to 0 when the Synopsys PHY is used.                             |
| [9]   | RW | lfps_filter          | LFPS filtering signal<br>1: The controller filters the LFPS signal from the PHY until pipe3_Rxelecidle and pipe3_RxValid are deasserted.<br>0: The controller does not filter the LFPS signal from the PHY.                                                                                       |
| [8]   | RW | polling_lfps_control | LFPS polling control after RX detection<br>0: (default) LFPS polling starts 400 µs later after RX detection.<br>1: LFPS polling starts after RX detection without delay.                                                                                                                          |
| [7]   | -  | reserved             | Reserved                                                                                                                                                                                                                                                                                          |
| [6]   | RW | txswing              | TX swing of the PIPE interface                                                                                                                                                                                                                                                                    |
| [5:3] | RW | txmargin             | TX margin of the PIPE interface                                                                                                                                                                                                                                                                   |
| [2:1] | RW | txdeemphasis         | TX preemphasis of the PIPE interface                                                                                                                                                                                                                                                              |
| [0]   | RW | elastic_buffer_mode  | Elastic buffer mode                                                                                                                                                                                                                                                                               |

## PERI\_USB3\_GTXFIFOSIZN

PERI\_USB3\_GTXFIFOSIZN is a global TX FIFO size register.

| Offset Address    |                                                                                                                                                                                                                                                                             | Register Name         |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  |          | Total Reset Value |  |  |  |  |  |  |  |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|---------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|----------|-------------------|--|--|--|--|--|--|--|--|--|
| 0xC300 + 0x04 x f |                                                                                                                                                                                                                                                                             | PERI_USB3_GTXFIFOSIZN |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  |          | 0x0000_0000       |  |  |  |  |  |  |  |  |  |
| (f = 0~31)        |                                                                                                                                                                                                                                                                             |                       |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  |          |                   |  |  |  |  |  |  |  |  |  |
| Bit               | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0                                                                                                                                                                         |                       |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  |          |                   |  |  |  |  |  |  |  |  |  |
| Name              | txfstaddr_n                                                                                                                                                                                                                                                                 |                       |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  | txfdep_n |                   |  |  |  |  |  |  |  |  |  |
| Reset             | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0 |                       |  |                                                   |  |  |  |  |  |  |  |  |  |  |  |  |          |                   |  |  |  |  |  |  |  |  |  |
| Bits              | Access                                                                                                                                                                                                                                                                      | Name                  |  | Description                                       |  |  |  |  |  |  |  |  |  |  |  |  |          |                   |  |  |  |  |  |  |  |  |  |
| [31:16]           | RW                                                                                                                                                                                                                                                                          | txfstaddr_n           |  | Start address for the TX FIFO n RAM in the memory |  |  |  |  |  |  |  |  |  |  |  |  |          |                   |  |  |  |  |  |  |  |  |  |



|        |    |          |                                                                                                |
|--------|----|----------|------------------------------------------------------------------------------------------------|
| [15:0] | RW | txfdep_n | TX FIFO depth<br>Minimum value: 32 MDWIDTH-bit words<br>Maximum value: 32768 MDWIDTH-bit words |
|--------|----|----------|------------------------------------------------------------------------------------------------|

## PERI\_USB3\_GRXFIFOSIZN

PERI\_USB3\_GRXFIFOSIZN is a global RX FIFO size register.

|         | Offset Address<br>0xC380 + 0x04 x f<br>(f = 0-31) |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GRXFIFOSIZN |                                                                                                |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |  |
|---------|---------------------------------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|------------------------------------------------------------------------------------------------|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|--|
| Bit     | 31                                                | 30          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                                     | 14                                                                                             | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name    | rxfstaddr_n                                       |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | rxfdep_n                               |                                                                                                |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| Reset   | 0                                                 | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                      | 0                                                                                              | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |  |
| Bits    | Access                                            | Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        | Description                                                                                    |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| [31:16] | RW                                                | rxfstaddr_n |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        | Start address for the RX FIFO n RAM in the memory                                              |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| [15:0]  | RW                                                | rxfdep_n    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        | RX FIFO depth<br>Minimum value: 32 MDWIDTH-bit words<br>Maximum value: 32768 MDWIDTH-bit words |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |

## PERI\_USB3\_GEVNTADRN\_LO

PERI\_USB3\_GEVNTADRN\_LO is a global event buffer address register.

|        | Offset Address<br>0xC400 + 0x10 x e<br>(e = 0-31) |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GEVNTADRN_LO |                                          |    |    |    |    |   |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |  |
|--------|---------------------------------------------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|------------------------------------------|----|----|----|----|---|---|----------------------------------|---|---|---|---|---|---|---|--|
| Bit    | 31                                                | 30        | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                                      | 14                                       | 13 | 12 | 11 | 10 | 9 | 8 | 7                                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Name   | evntadrlo                                         |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         |                                          |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| Reset  | 0                                                 | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                       | 0                                        | 0  | 0  | 0  | 0  | 0 | 0 | 0                                | 0 | 0 | 0 | 0 | 0 |   |   |  |
| Bits   | Access                                            | Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | Description                              |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |
| [31:0] | RWSC                                              | evntadrlo |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | Lower 32-bit address of the event buffer |    |    |    |    |   |   |                                  |   |   |   |   |   |   |   |  |

## PERI\_USB3\_GEVNTADRN\_HI

PERI\_USB3\_GEVNTADRN\_HI is a global event buffer address register.



| Offset Address<br>0xC404 + 0x10 x e<br>(e = 0–31) |           |           |    |                                          |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GEVNTADRN_HI |    |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |
|---------------------------------------------------|-----------|-----------|----|------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|----|----|----|----|----|----|---|----------------------------------|---|---|---|---|---|---|---|---|
| Bit                                               | 31        | 30        | 29 | 28                                       | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                              | evntadrhi |           |    |                                          |    |    |    |    |    |    |    |    |    |    |    |                                         |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| Reset                                             | 0         | 0         | 0  | 0                                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                       | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits                                              | Access    | Name      |    | Description                              |    |    |    |    |    |    |    |    |    |    |    |                                         |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [31:0]                                            | RWSC      | evntadrhi |    | Upper 32-bit address of the event buffer |    |    |    |    |    |    |    |    |    |    |    |                                         |    |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |

## PERI\_USB3\_GEVNTSIZN

PERI\_USB3\_GEVNTSIZN is a global event buffer size register.

| Offset Address<br>0xC408 + 0x10 x e<br>(e = 0–31) |             |             |    |                          |    |    |    |    |    |    |    |    |          |    |    | Register Name<br>PERI_USB3_GEVNTSIZN |    |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |         |   |   |   |   |   |   |   |
|---------------------------------------------------|-------------|-------------|----|--------------------------|----|----|----|----|----|----|----|----|----------|----|----|--------------------------------------|----|----|----|----|----|----|---|----------------------------------|---------|---|---|---|---|---|---|---|
| Bit                                               | 31          | 30          | 29 | 28                       | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19       | 18 | 17 | 16                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                              | evntintmask |             |    |                          |    |    |    |    |    |    |    |    | reserved |    |    |                                      |    |    |    |    |    |    |   |                                  | evntsiz |   |   |   |   |   |   |   |
| Reset                                             | 0           | 0           | 0  | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0       | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits                                              | Access      | Name        |    | Description              |    |    |    |    |    |    |    |    |          |    |    |                                      |    |    |    |    |    |    |   |                                  |         |   |   |   |   |   |   |   |
| [31]                                              | RW          | evntintmask |    | Event interrupt mask     |    |    |    |    |    |    |    |    |          |    |    |                                      |    |    |    |    |    |    |   |                                  |         |   |   |   |   |   |   |   |
| [30:16]                                           | -           | reserved    |    | Reserved                 |    |    |    |    |    |    |    |    |          |    |    |                                      |    |    |    |    |    |    |   |                                  |         |   |   |   |   |   |   |   |
| [15:0]                                            | RW          | evntsiz     |    | Event buffer size (byte) |    |    |    |    |    |    |    |    |          |    |    |                                      |    |    |    |    |    |    |   |                                  |         |   |   |   |   |   |   |   |

## PERI\_USB3\_GEVNTCOUNTN

PERI\_USB3\_GEVNTCOUNTN is a global event buffer count register.



| Offset Address<br>0xC40C + 0x10 x e<br>(e = 0–31) |          |           |    |                                                                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GEVNTCOUNTN |           |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |
|---------------------------------------------------|----------|-----------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|-----------|----|----|----|----|----|---|----------------------------------|---|---|---|---|---|---|---|---|
| Bit                                               | 31       | 30        | 29 | 28                                                                                                                                                                | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                     | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                                              | reserved |           |    |                                                                                                                                                                   |    |    |    |    |    |    |    |    |    |    |    |                                        | evntcount |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| Reset                                             | 0        | 0         | 0  | 0                                                                                                                                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                      | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits                                              | Access   | Name      |    | Description                                                                                                                                                       |    |    |    |    |    |    |    |    |    |    |    |                                        |           |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [31:16]                                           | RO       | reserved  |    | Reserved                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |                                        |           |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [15:0]                                            | RWSC     | evntcount |    | When this register is read, the number of valid events in the event buffer is returned; when it is written, the hardware automatically decreases the count value. |    |    |    |    |    |    |    |    |    |    |    |                                        |           |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |

## PERI\_USB3\_GTXFIFOPRIDEV

PERI\_USB3\_GTXFIFOPRIDEV is a peripheral global TX FIFO DMA priority register.

| Offset Address<br>0xC610 |          |                        |    |                                                     |    |    |    |    |    |    |    |    |    |    |    | Register Name<br>PERI_USB3_GTXFIFOPRIDEV |                        |    |    |    |    |    |   | Total Reset Value<br>0x0000_0000 |   |   |   |   |   |   |   |   |
|--------------------------|----------|------------------------|----|-----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|------------------------|----|----|----|----|----|---|----------------------------------|---|---|---|---|---|---|---|---|
| Bit                      | 31       | 30                     | 29 | 28                                                  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                       | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8                                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name                     | reserved |                        |    |                                                     |    |    |    |    |    |    |    |    |    |    |    |                                          | device_txfifo_priority |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| Reset                    | 0        | 0                      | 0  | 0                                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                        | 0                      | 0  | 0  | 0  | 0  | 0  | 0 | 0                                | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits                     | Access   | Name                   |    | Description                                         |    |    |    |    |    |    |    |    |    |    |    |                                          |                        |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [31:4]                   | -        | reserved               |    | Reserved                                            |    |    |    |    |    |    |    |    |    |    |    |                                          |                        |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |
| [3:0]                    | 0x0      | device_txfifo_priority |    | Priority of the device TX FIFO<br>1: high<br>0: low |    |    |    |    |    |    |    |    |    |    |    |                                          |                        |    |    |    |    |    |   |                                  |   |   |   |   |   |   |   |   |

## PERI\_USB3\_GTXFIFOPRIHST

PERI\_USB3\_GTXFIFOPRIHST is a host global TX FIFO DMA priority register.



| Offset Address |          |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    | Register Name           |    |    |    |    |    |    |   | Total Reset Value |   |                      |   |   |   |   |   |   |
|----------------|----------|----------------------|----|----|---------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|---|-------------------|---|----------------------|---|---|---|---|---|---|
| 0xC618         |          |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    | PERI_USB3_GTXFIFOPRIHST |    |    |    |    |    |    |   | 0x0000_0000       |   |                      |   |   |   |   |   |   |
| Bit            | 31       | 30                   | 29 | 28 | 27                                                | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   | host_txfifo_priority |   |   |   |   |   |   |
| Reset          | 0        | 0                    | 0  | 0  | 0                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0                    | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name                 |    |    | Description                                       |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |
| [31:4]         | -        | reserved             |    |    | Reserved                                          |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |
| [3:0]          | RW       | host_txfifo_priority |    |    | Priority of the host TX FIFO<br>1: high<br>0: low |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |

## PERI\_USB3\_GRXFIFOPRIHST

PERI\_USB3\_GRXFIFOPRIHST is a host global RX FIFO DMA priority register.

| Offset Address |          |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    | Register Name           |    |    |    |    |    |    |   | Total Reset Value |   |                      |   |   |   |   |   |   |
|----------------|----------|----------------------|----|----|---------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|---|-------------------|---|----------------------|---|---|---|---|---|---|
| 0xC61C         |          |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    | PERI_USB3_GRXFIFOPRIHST |    |    |    |    |    |    |   | 0x0000_0000       |   |                      |   |   |   |   |   |   |
| Bit            | 31       | 30                   | 29 | 28 | 27                                                | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                      |    |    |                                                   |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   | host_rxfifo_priority |   |   |   |   |   |   |
| Reset          | 0        | 0                    | 0  | 0  | 0                                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                 | 0 | 0                    | 0 | 0 | 0 | 0 | 0 |   |
| Bits           | Access   | Name                 |    |    | Description                                       |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |
| [31:4]         | -        | reserved             |    |    | Reserved                                          |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |
| [3:0]          | RW       | host_rxfifo_priority |    |    | Priority of the host RX FIFO<br>1: high<br>0: low |    |    |    |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |   |                   |   |                      |   |   |   |   |   |   |

## PERI\_USB3\_GFIFOPRIDBC

PERI\_USB3\_GFIFOPRIDBC is a host global performance debug DMA priority register.



## PERI USB3 GDMAHLRATIO

**PERI\_USB3\_GDMAHLRATIO** is a high/low priority ratio register for the host global FIFO DMA.

| Offset Address |          |                                     |      |                                                 |             |    |    | Register Name         |    |    |    |    |                                     |    |    | Total Reset Value |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------|----------|-------------------------------------|------|-------------------------------------------------|-------------|----|----|-----------------------|----|----|----|----|-------------------------------------|----|----|-------------------|----------|----|----|----|-------------------------------------|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|--|--|--|--|
| 0xC624         |          |                                     |      |                                                 |             |    |    | PERI_USB3_GDMAHLRATIO |    |    |    |    |                                     |    |    | 0x0000_0000       |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit            | 31       | 30                                  | 29   | 28                                              | 27          | 26 | 25 | 24                    | 23 | 22 | 21 | 20 | 19                                  | 18 | 17 | 16                | 15       | 14 | 13 | 12 | 11                                  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |
| Name           | reserved |                                     |      |                                                 |             |    |    |                       |    |    |    |    | hst_rx_fifo_dma_hilo_priority_ratio |    |    |                   | reserved |    |    |    | hst_tx_fifo_dma_hilo_priority_ratio |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset          | 0        | 0                                   | 0    | 0                                               | 0           | 0  | 0  | 0                     | 0  | 0  | 0  | 0  | 0                                   | 0  | 0  | 0                 | 0        | 0  | 0  | 0  | 0                                   | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
|                | Bits     | Access                              | Name |                                                 | Description |    |    |                       |    |    |    |    |                                     |    |    |                   |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| [31:13]        | -        | reserved                            |      | Reserved                                        |             |    |    |                       |    |    |    |    |                                     |    |    |                   |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| [12:8]         | RW       | hst_rx_fifo_dma_hilo_priority_ratio |      | High/Low priority ratio of the host RX FIFO DMA |             |    |    |                       |    |    |    |    |                                     |    |    |                   |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |
| [7:5]          | -        | reserved                            |      | Reserved                                        |             |    |    |                       |    |    |    |    |                                     |    |    |                   |          |    |    |    |                                     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |  |  |  |  |



|       |    |                                    |                                                 |
|-------|----|------------------------------------|-------------------------------------------------|
| [4:0] | RW | hst_txfifo_dma_hilo_priority_ratio | High/Low priority ratio of the host TX FIFO DMA |
|-------|----|------------------------------------|-------------------------------------------------|

## PERI\_USB3\_GFLADJ

PERI\_USB3\_GFLADJ is a global frame length adjustment register.

|         | Offset Address                                                                                      | Register Name                     | Total Reset Value                                                                                                                                                                                               |
|---------|-----------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20   19 18 17 16   15 14 13 12   11 10 9 8   7 6 5 4   3 2 1 0 | PERI_USB3_GFLADJ                  | 0x0000_0000                                                                                                                                                                                                     |
| Name    | gfladj_refclk_240mhzdecr_pls1<br>gfladj_refclk_240mhz_decr                                          | gfladj_refclk_lpm_sel<br>reserved | gfladj_refclk_fladj<br>gfladj_30mhz_reg_sel<br>reserved                                                                                                                                                         |
| Reset   | 0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0   0 0 0 0                       |                                   |                                                                                                                                                                                                                 |
| Bits    | Access                                                                                              | Name                              | Description                                                                                                                                                                                                     |
| [31]    | RW                                                                                                  | gfladj_refclk_240mhzdecr_pls1     | Precision of GFLADJ_REFCLK_240MHZ_DECR/ref_frequency<br>0: The remainder is less than 0.5.<br>1: The remainder is greater than or equal to 0.5.                                                                 |
| [30:24] | RW                                                                                                  | gfladj_refclk_240mhz_decr         | GFLADJ_REFCLK_240MHZ_DECR = 240/ref_clk_frequency                                                                                                                                                               |
| [23]    | RW                                                                                                  | gfladj_refclk_lpm_sel             | SOF/ITP count clock select<br>If this bit is set to 1, ref_clk is the count clock.                                                                                                                              |
| [22]    | -                                                                                                   | reserved                          | Reserved                                                                                                                                                                                                        |
| [21:8]  | RW                                                                                                  | gfladj_refclk_fladj               | SOF/ITP calibration value when bit 23 is 1<br>$\text{FLADJ\_REF\_CLK\_FLADJ} = ((125000/\text{ref\_clk\_period\_integer}) - (125000/\text{ref\_clk\_period})) \times \text{ref\_clk\_period}$                   |
| [7]     | RW                                                                                                  | gfladj_30mhz_reg_sel              | SOF/ITP calibration select<br>1: The controller calibrates the SOF/ITP based on the value of PERI_USB3_GFLADJ[gfladj_30mhz].<br>0: The controller calibrates the SOF/ITP based on the value of fladj_30mhz_reg. |
| [6]     | -                                                                                                   | reserved                          | Reserved                                                                                                                                                                                                        |



|       |    |              |                                                                                                                                      |
|-------|----|--------------|--------------------------------------------------------------------------------------------------------------------------------------|
| [5:0] | RW | gfladj_30mhz | When bit 7 is 1 and the SOF/ITP count clock is the UTMI/ULPI clock, the controller calibrates the SOF/ITP based on this field value. |
|-------|----|--------------|--------------------------------------------------------------------------------------------------------------------------------------|

## PERI\_USB5

PERI\_USB5 is USB 3.0 system controller 0.

|         | Offset Address                          | Register Name                                   | Total Reset Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-----------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit     | 31 30 29 28   27 26 25 24   23 22 21 20 | PERI_USB5                                       | 0x7E80_2040                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Name    | host_current_belt                       | bus_filter_bypass<br>chirp_on<br>reserved       | fladj_30mhz_reg<br>host_msi_enable<br>host_port_power_control_present<br>hub_u3_port_disable<br>hub_u2_port_disable<br>hub_port_perm_attach<br>reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| Reset   | 0 1 1 1   1 1 1 0   1 0 0 0             | 0 0 0 0   0 0 1 0   0 0 0 0   0 1 0 0   0 0 0 0 | 0 1 0 0   0 0 0 0   0 0 0 0   0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bits    | Access                                  | Name                                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [31:20] | RW                                      | host_current_belt                               | Current BELT value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [19:16] | RW                                      | bus_filter_bypass                               | UTMI bus signal filtering enable. The value 1 indicates disabled, and the value 0 indicates enabled.<br>bus_filter_bypass[3]<br>The function of filtering out the utmiotg_iddig signal is disabled.<br>bus_filter_bypass[2]<br>The function of filtering out utmisrp_bvalid and utmisrp_sessend signals is disabled.<br>bus_filter_bypass[1]<br>The function of filtering out all pipe3_PowerPresent signal of port U3 is disabled.<br>bus_filter_bypass[0]<br>The function of filtering out all utmiotg_vbusvalid signal of port U2 is disabled. |
| [15]    | RW                                      | chirp_on                                        | Chirp signal detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [14]    | RW                                      | reserved                                        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



|        |    |                                 |                                                                                                                    |
|--------|----|---------------------------------|--------------------------------------------------------------------------------------------------------------------|
| [13:8] | RW | fladj_30mhz_reg                 | High-speed signal jitter adjust<br>The mac3_clock and utmi_clock are adjusted to 125 μs.                           |
| [7]    | RW | host_msi_enable                 | Pulse interrupt enable<br>1: Interrupt signals are output as pulses.<br>0: Interrupt signals are output as levels. |
| [6]    | RW | host_port_power_control_present | Port power switch enable<br>0: The port has no power switch.<br>1: The port has a power switch.                    |
| [5]    | RW | hub_u3_port_disable             | USB 3.0 super-speed port enable<br>0: enabled<br>1: disabled                                                       |
| [4]    | RW | hub_u2_port_disable             | USB 3.0 high-speed port enable.<br>0: enabled<br>1: disabled                                                       |
| [3:2]  | RW | hub_port_perm_attach            | Device permanent insertion<br>0: yes<br>1: no                                                                      |
| [1:0]  | RW | reserved                        | Reserved                                                                                                           |

## PERI\_USB6

PERI\_USB6 is USB 3.0 PCS system controller 1.

|       | Offset Address |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | Register Name     |                  |                     |                    |                             |                          |                    |          | Total Reset Value |   |              |   |   |   |   |   |  |  |
|-------|----------------|----------|----|----|----|-------------|----|----|----|----|----|----|----|----|----|----|-------------------|------------------|---------------------|--------------------|-----------------------------|--------------------------|--------------------|----------|-------------------|---|--------------|---|---|---|---|---|--|--|
|       | 0x0138         |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | PERI_USB6         |                  |                     |                    |                             |                          |                    |          | 0x5D81_560D       |   |              |   |   |   |   |   |  |  |
| Bit   | 31             | 30       | 29 | 28 | 27 | 26          | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15                | 14               | 13                  | 12                 | 11                          | 10                       | 9                  | 8        | 7                 | 6 | 5            | 4 | 3 | 2 | 1 | 0 |  |  |
| Name  | reserved       |          |    |    |    |             |    |    |    |    |    |    |    |    |    |    | pcs_tx_swing_full | pcs_tx_deemh_6db | pcs_tx_deemph_3p5db | lane0_tx2rx_loophk | lane0_power_present_ovrd_en | lane0_power_present_ovrd | lane0_ext_pclk_req | reserved |                   |   | usb_pwr_ctrl |   |   |   |   |   |  |  |
| Reset | 0              | 1        | 0  | 1  | 1  | 1           | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1                 | 0                | 1                   | 0                  | 1                           | 0                        | 1                  | 1        | 0                 | 0 | 0            | 0 | 1 | 1 | 0 | 1 |  |  |
| Bits  | Access         | Name     |    |    |    | Description |    |    |    |    |    |    |    |    |    |    |                   |                  |                     |                    |                             |                          |                    |          |                   |   |              |   |   |   |   |   |  |  |
| [31]  | RW             | reserved |    |    |    | Reserved    |    |    |    |    |    |    |    |    |    |    |                   |                  |                     |                    |                             |                          |                    |          |                   |   |              |   |   |   |   |   |  |  |



|         |    |                            |                                                                                                                                                                                                                                                                                                                                                      |
|---------|----|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [30:24] | RW | pcs_tx_swing_full          | TX signal swing (for the eye pattern test)                                                                                                                                                                                                                                                                                                           |
| [23:18] | RW | pcs_tx_deemh_6db           | Preemphasis of 6 dB reduction (for the eye pattern test)                                                                                                                                                                                                                                                                                             |
| [17:12] | RW | pcs_tx_deemph_3p5db        | Preemphasis of 3.5 dB reduction (for the eye pattern test)                                                                                                                                                                                                                                                                                           |
| [11]    | RW | lane0_tx2rx_lopbk          | Lane 0 TX-to-RX loopback enable                                                                                                                                                                                                                                                                                                                      |
| [10]    | RW | lane0_power_preset_ovrd_en | Lane 0 overcurrent protection enable<br>1: enabled<br>0: disabled                                                                                                                                                                                                                                                                                    |
| [9]     | RW | lane0_power_preset_ovrd    | Lane 0 overcurrent protection<br>1: enabled<br>0: disabled                                                                                                                                                                                                                                                                                           |
| [8]     | RW | lane0_ext_pclk_req         | Lane 0 external PIPE clock enable<br>1: enabled<br>0: disabled                                                                                                                                                                                                                                                                                       |
| [7:4]   | RW | reserved                   | Reserved                                                                                                                                                                                                                                                                                                                                             |
| [3:0]   | RW | usb_pwr_ctrl               | Power control<br>Bit[0]: power switch control signal<br>1: on<br>0: off<br>Bit[1]: overcurrent protection enable signal<br>1: enabled<br>0: disabled<br>Bit[2]: power switch polarity inversion enable signal<br>1: inverted<br>0: not inverted<br>Bit[3]: overcurrent protection polarity inversion enable signal<br>1: inverted<br>0: not inverted |

## PERI\_USB7

PERI\_USB7 is USB 3.0 PHY system controller 0.



| Offset Address |          |           |    |    |                     |    |    | Register Name |    |    |    |    |           |    |    | Total Reset Value |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|----------|-----------|----|----|---------------------|----|----|---------------|----|----|----|----|-----------|----|----|-------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x013C         |          |           |    |    |                     |    |    | PERI_USB7     |    |    |    |    |           |    |    | 0x0000_0000       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31       | 30        | 29 | 28 | 27                  | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16                | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | crdatain |           |    |    |                     |    |    |               |    |    |    |    | crdataout |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0        | 0         | 0  | 0  | 0                   | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name      |    |    | Description         |    |    |               |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:16]        | RW       | crdatain  |    |    | Current input data  |    |    |               |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:0]         | RW       | crdataout |    |    | Current output data |    |    |               |    |    |    |    |           |    |    |                   |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

PERI\_USB8

PERI\_USB8 is USB 3.0 PHY system controller 1.

| Offset Address |         |                |                |                                                                                                                         |          |         |              | Register Name |        |         |              |         |       |        |        | Total Reset Value |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------------|---------|----------------|----------------|-------------------------------------------------------------------------------------------------------------------------|----------|---------|--------------|---------------|--------|---------|--------------|---------|-------|--------|--------|-------------------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0x0140         |         |                |                |                                                                                                                         |          |         |              | PERI_USB8     |        |         |              |         |       |        |        | 0x0000_0000       |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit            | 31      | 30             | 29             | 28                                                                                                                      | 27       | 26      | 25           | 24            | 23     | 22      | 21           | 20      | 19    | 18     | 17     | 16                | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | otgtune | otgdisable0    | mpllrefssclken | mpllmultiplier                                                                                                          | loslevel | losbias | loopbackenb0 | idpullup0     | iddig0 | drvbus0 | compdistune0 | common0 | crack | crwrit | ciread | ercapdata         | ercapaddr |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset          | 0       | 0              | 0              | 0                                                                                                                       | 0        | 0       | 0            | 0             | 0      | 0       | 0            | 0       | 0     | 0      | 0      | 0                 | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access  | Name           |                | Description                                                                                                             |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [31:29]        | RW      | otgtune        |                | Vbus valid threshold adjust<br>1 bit = 1.5%                                                                             |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [28]           | RW      | otgdisable0    |                | PHY OTG disable                                                                                                         |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [27]           | RW      | mpllrefssclken |                | Spread reference clock output. It is 20 MHz and provides the clock for the hardcore of the clock source of ref_alt_clk. |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [26:20]        | RW      | mpllmultiplier |                | MPLL frequency multiplier control for obtaining a specified working frequency                                           |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [19:16]        | RW      | loslevel       |                | Sensitivity level detection for the loss-of-signal (LOS) detector                                                       |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [15:13]        | RW      | losbias        |                | Level threshold detection for the LOS detector                                                                          |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| [12]           | RW      | loopbackenb0   |                | Loopback enable<br>1: enabled<br>0: disabled                                                                            |          |         |              |               |        |         |              |         |       |        |        |                   |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



|       |    |              |                                                                                                                                                                       |
|-------|----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11]  | RW | idpullup0    | Sampling enable for the analog ID input signal<br>1: enabled<br>0: disabled                                                                                           |
| [10]  | RW | iddig0       | Mini-A or mini-B connector connected to the PHY<br>1: mini-B connector<br>0: mini-A connector                                                                         |
| [9]   | RW | drvbus0      | Vbus valid comparator enable<br>1: enabled<br>0: disabled                                                                                                             |
| [8:6] | RW | compdistune0 | Disconnection event detection voltage threshold. This field is used to set the voltage threshold for the disconnection event between the device and the host.         |
| [5]   | RW | commomon0    | Common module enable<br>1: The HS bias and PLL modules are disabled in suspend or sleep mode.<br>0: The HS bias and PLL modules are enabled in suspend or sleep mode. |
| [4]   | RW | crack        | Controller signal (as the response to the CRWRITE, CRREAD, CRCAPDATA, and CRCAPSDDR signals)                                                                          |
| [3]   | RW | crwrite      | Register write control signal                                                                                                                                         |
| [2]   | RW | crread       | Register read control signal                                                                                                                                          |
| [1]   | RW | crcapdata    | Register data capture control signal. cr_data_in[15:0] are transferred to the written data.                                                                           |
| [0]   | RW | crcapaddr    | Register address capture control signal. cr_data_in[15:0] are transferred to the address register.                                                                    |

## PERI\_USB9

PERI\_USB9 is USB 3.0 PHY system controller 2.



|         | Offset Address<br>0x0144 |                   |             |                                                                                                                                                             |    |    |               |    |    |    |    |    |    |    |          |             | Register Name<br>PERI_USB9 |    |    |    |         |       |           |   | Total Reset Value<br>0x0000_0000 |   |           |   |   |   |   |   |
|---------|--------------------------|-------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---------------|----|----|----|----|----|----|----|----------|-------------|----------------------------|----|----|----|---------|-------|-----------|---|----------------------------------|---|-----------|---|---|---|---|---|
| Bit     | 31                       | 30                | 29          | 28                                                                                                                                                          | 27 | 26 | 25            | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16          | 15                         | 14 | 13 | 12 | 11      | 10    | 9         | 8 | 7                                | 6 | 5         | 4 | 3 | 2 | 1 | 0 |
| Name    | txpreemppulse0           | txpreempamp tune0 | txfusltune0 |                                                                                                                                                             |    |    | sscrefclk sel |    |    |    |    |    |    |    | reserved | txhsxvtune0 | tx0termoffset              |    |    |    | ssrange | sscen | sqrxtune0 |   |                                  |   | refenable |   |   |   |   |   |
| Reset   | 0                        | 0                 | 0           | 0                                                                                                                                                           | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0           | 0                          | 0  | 0  | 0  | 0       | 0     | 0         | 0 | 0                                | 0 | 0         | 0 | 0 |   |   |   |
| Bits    | Access                   | Name              |             | Description                                                                                                                                                 |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [31]    | RW                       | txpreemppulse0    |             | TX preemphasis time in high-speed mode<br>1: 580 μs<br>0: 2 x 580 μs                                                                                        |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [30:29] | RW                       | txpreempamp tune0 |             | TX preemphasis tune in high-speed mode<br>11: 1800 μA<br>10: 1200 μA<br>01: 600<br>00: Preemphasis is disabled                                              |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [28:25] | RW                       | txfusltune0       |             | Source impedance tune in full-speed or low-speed mode by using hot codes. The impedance is decreased by 2.5% each time a hot code is added, and vice versa. |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [24:16] | RW                       | sscrefclk sel     |             | Spread spectrum reference clock select                                                                                                                      |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [15]    | RW                       | reserved          |             | Reserved                                                                                                                                                    |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [14:13] | RW                       | txhsxvtune0       |             | TX DP/DM voltage tune in high-speed mode<br>11: default configuration<br>10: +15 mV<br>01: -15 mV<br>00: reserved                                           |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [12:8]  | RW                       | tx0termoffset     |             | TX termination compensation tune enable<br>1: enabled<br>0: disabled                                                                                        |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [7:5]   | RW                       | ssrange           |             | Spread spectrum clock range                                                                                                                                 |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |
| [4]     | RW                       | sscen             |             | Spread spectrum enable<br>1: enabled<br>0: disabled                                                                                                         |    |    |               |    |    |    |    |    |    |    |          |             |                            |    |    |    |         |       |           |   |                                  |   |           |   |   |   |   |   |



|       |    |            |                                                                                                                                                                               |
|-------|----|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:1] | RW | sqrxtune0  | High-speed data detection level tune<br>The level is decreased by 5% each time a binary value is added, and vice versa.                                                       |
| [0]   | RW | retenablen | Low digital power indicator, indicating that the VP digital power is decreased in suspend mode.<br>1: The normal operating mode is used.<br>0: The analog power is shut down. |

PERI\_USB10

PERI\_USB10 is USB 3.0 PHY system controller 3.

| Offset Address |          |                  |    |                                                                                                                                                                                      |    |    |    | Register Name |                |             |             |    |    |    |          | Total Reset Value |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
|----------------|----------|------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|---------------|----------------|-------------|-------------|----|----|----|----------|-------------------|----|------------------|----|--------|---------|-------------|--------------|-------------|---|------------|---|---|---|---|---|---|
| 0x0148         |          |                  |    |                                                                                                                                                                                      |    |    |    | PERI_USB10    |                |             |             |    |    |    |          | 0x0000_0000       |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| Bit            | 31       | 30               | 29 | 28                                                                                                                                                                                   | 27 | 26 | 25 | 24            | 23             | 22          | 21          | 20 | 19 | 18 | 17       | 16                | 15 | 14               | 13 | 12     | 11      | 10          | 9            | 8           | 7 | 6          | 5 | 4 | 3 | 2 | 1 | 0 |
| Name           | reserved |                  |    |                                                                                                                                                                                      |    |    |    |               | vbusvldextsel0 | vbusvldext0 | txvreftune0 |    |    |    | reserved | testpowerdownssp  |    | testpowerdownssp |    | rtunek | rtunreq | vdatsrcenb0 | vdalddetenb0 | txrisetune0 |   | txrestune0 |   |   |   |   |   |   |
| Reset          | 0        | 0                | 0  | 0                                                                                                                                                                                    | 0  | 0  | 0  | 0             | 0              | 0           | 0           | 0  | 0  | 0  | 0        | 0                 | 0  | 0                | 0  | 0      | 0       | 0           | 0            | 0           | 0 | 0          | 0 | 0 | 0 | 0 |   |   |
| Bits           | Access   | Name             |    | Description                                                                                                                                                                          |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [31:19]        | RW       | reserved         |    | Reserved                                                                                                                                                                             |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [18]           | RW       | vbusvldextsel0   |    | External Vbus valid indicator<br>1: VBUSVLDEXT0<br>0: internal comparator                                                                                                            |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [17]           | RW       | vbusvldext0      |    | External Vbus valid indicator signal<br>1: The Vbus0 signal and the pull-up resistor on D+ are valid.<br>0: The Vbus0 signal is invalid, and the pull-up resistor on D+ is disabled. |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [16:13]        | RW       | txvreftune0      |    | DC voltage tune in high-speed mode<br>The voltage is increased by 1.25% each time the binary value 1 is added, and vice versa.                                                       |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [12:10]        | RW       | reserved         |    | Reserved                                                                                                                                                                             |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |
| [9]            | RW       | testpowerdownssp |    | Power-off control for the super-speed function circuit<br>1: turned off<br>0: not turned off                                                                                         |    |    |    |               |                |             |             |    |    |    |          |                   |    |                  |    |        |         |             |              |             |   |            |   |   |   |   |   |   |



|       |    |                  |                                                                                                                                                                           |
|-------|----|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]   | RW | testpowerdownhsp | Power-off control for the high-speed function circuit<br>1: turned off<br>0: not turned off                                                                               |
| [7]   | RW | rtunreak         | Impedance tune acknowledge enable                                                                                                                                         |
| [6]   | RW | rtunreq          | Impedance tune request                                                                                                                                                    |
| [5]   | RW | vdatsrcenb0      | Charging power select<br>1: The data source voltage (VDAT_SRC) is enabled.<br>0: The data source voltage (VDAT_SRC) is disabled.                                          |
| [4]   | RW | vdatdetenb0      | Charging connection/disconnection detection enable<br>1: The data detection voltage is enabled.<br>0: The data detection voltage is disabled.                             |
| [3:2] | RW | txrisetune0      | Rising/Falling edge time tune for the TX end in high-speed mode<br>The rising/falling edge time is decreased by 4% each time the binary value 1 is added, and vice versa. |
| [1:0] | RW | txrestune0       | USB matched source impedance tune                                                                                                                                         |

## PERI\_USB12

PERI\_USB12 is USB 3.0 system controller 3.

|         | Offset Address |                     |    |    |                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    | Register Name |    |    |    |    |    |   |   | Total Reset Value   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|---------|----------------|---------------------|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|---|---|---------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
|         | 0x014C         |                     |    |    |                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    | PERI_USB12    |    |    |    |    |    |   |   | 0x0000_0000         |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Bit     | 31             | 30                  | 29 | 28 | 27                                                                                                                                                                       | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |  |  |  |  |  |  |  |
| Name    | reserved       |                     |    |    |                                                                                                                                                                          |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   | pcs_rx_los_mask_val |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Reset   | 0              | 0                   | 0  | 0  | 0                                                                                                                                                                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0                   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |
| Bits    | Access         | Name                |    |    | Description                                                                                                                                                              |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| [31:10] | RW             | reserved            |    |    | Reserved                                                                                                                                                                 |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| [9:0]   | RW             | pcs_rx_los_mask_val |    |    | Number of reference clock cycles for masking the LFPS signals that are being received<br>Value = 10 µs/Tref_clk<br>If ref_clkdiv2 is used, Value = 10 µs/(2 x Tref_clk). |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |    |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |



## 11.9 SCI

### 11.9.1 Overview

The SCI is located on the APB and is provided for the external card reader. The CPU reads data from or writes data to the smart card through the SCI and implements serial-to-parallel conversion (when reads data from the smart card) and parallel-to-serial conversion (when writes data to the smart card).

### 11.9.2 Features

The SCI has the following features:

- Supports the ISO/IEC 7816-3, 7816-10, and EMV standards and the T0, T1, and T14 asynchronous transmission protocols.
- Supports the configurable card clock rate and elementary time unit (ETU).
- Supports data transfer without transmitting a parity bit.
- Provides a 32-byte internal TX FIFO and a 32-byte internal RX FIFO.
- Allows hardware to detect the FIFO depth and reports corresponding interrupts.
- Queries 15 types of maskable and independent interrupts and reports one combined interrupt.
- Queries raw and masked interrupt status.
- Allows software to activate a smart card after it is inserted.
- Allows software to release a smart card after it completes data transfer.
- Allows hardware to release a smart card when its removal is detected.
- Supports the SCI soft reset.
- Supports the clock rate conversion factor F of 372 or 512 and the bit rate adjustment factor D of 1, 2, 4, 8, or 16.

### 11.9.3 Function Description

#### 11.9.3.1 Application Block Diagram

Figure 11-46 shows the typical application circuit of the SCI.



#### CAUTION

- When `SCI_CR1[clkz1]` is set to 0, that is, during CMOS output, the `SCI_CLK` pin does not need to connect to pull-up resistors on the board.
- When `SCI_CR1[clkz1]` is set to 1, that is, during OD output, the `SCI_CLK` pin must connect to pull-up resistors on the board.
- When `PERI_SIM_OD_CTRL` bit[2] is set to 0, that is, during CMOS output, the `SCI0_RST` pin does not need to connect to pull-up resistors on the board.
- When `PERI_SIM_OD_CTRL` bit[2] is set to 1, that is, during OD output, the `SCI0_RST` pin must connect to pull-up resistors on the board.

- When PERI\_SIM\_OD\_CTRL bit[1] is set to 0, that is, during CMOS output, the SCI0\_PWREN pin does not need to connect to pull-up resistors on the board.
- When PERI\_SIM\_OD\_CTRL bit[1] is set to 1, that is, during OD output, the SCI0\_PWREN pin must connect to pull-up resistors on the board.
- SCI\_DATA must work in OD mode and connect to pull-up resistors on the board.

**Figure 11-46** Typical application circuit diagram of the SCI



#### NOTE

Vcc1 is a 3.3 V power supply on the board, whereas Vcc is the power supply for the smart card, which is provided by the 1.8 V, 3.3 V, or 5 V power of the power management module on the board.

The SCI controls whether the power management module supplies power to the smart card by using the SCI\_PWR\_EN signal. The power management module converts the voltage between the chip and the smart card to provide the 1.8 V, 3.3 V, or 5 V voltage, meeting requirements of various smart cards. When a smart card is inserted into the slot on the board, the card detection circuit sets the SCI\_DETECT signal to a valid value.

### 11.9.3.2 Function Implementation

#### Timing for Resetting the Smart Card

The SCI activates the smart card by sending the reset timing. To be specific, software writes 1 to [SCI\\_CR2\[startup\]](#) to complete the activation.

As shown in [Figure 11-47](#), the SCI activation timing consists of three phases. After a reset signal is sent, power is supplied at T1, the card clock is provided at T2, and the reset is deasserted at T3 to get ready to receive the answer to reset (ATR) data. After the SCI transmits the activation timing, the smart card provides ATR data at T4.

**Figure 11-47** Timing for resetting the smart card **NOTE**

The delay parameter SCIATIME is defined by configuring the [SCI\\_ATIME](#) register.

## Timing for Releasing the Smart Card

If the SCI does not receive ATR data within 400 to 40000 clock cycles of the smart card (defined in [SCI\\_ATRSTTIME](#)) after transmitting the activation timing, the SCI automatically starts the release timing without software intervention and transmits the ATR wait timeout interrupt ([SCI\\_RIS](#)[atrstoutim] is 1). After operations on the smart card are complete, the SCI releases the smart card. To be specific, software writes 1 to [SCI\\_CR2](#)[finish].

[Figure 11-48](#) shows the timing for releasing the smart card. The reset signal is provided at T0, the clock is cleared at T1, I/O is changed to high impedance at T2, and then the power supply is off at T3.

**Figure 11-48** Timing for releasing the smart card **NOTE**

The delay parameter SCIDTIME is defined by configuring the [SCI\\_DTIME](#) register.

## Timing for Soft-Resetting the Smart Card

If an error occurs in the received ATR data (for example, a timeout), the SCI sends a soft-reset timing to receive the ART timing again. To be specific, software writes 1 to [SCI\\_CR2](#)[wreset].

[Figure 11-49](#) shows the SCI timing for soft-resetting the smart card. Note that SCI\_PWR\_EN is always enabled.



**Figure 11-49** SCI timing for soft-resetting the smart card



## Character Transfer Structure

In asynchronous mode, bytes are transferred between the SCI and the smart card in a unified character transfer format. A byte is transmitted as 10 consecutive ETUs. During this process, one start bit, eight data bits, and one parity bit (optional) are transmitted. When the SCI data pin is idle, high impedance is output. Figure 11-50 shows the character transfer structure supported by the SCI.

**Figure 11-50** Character transfer structure supported by the SCI



S: an ETU for the duration of the start bit

P: parity bit

ETU: duration of 1-bit data



The data line in Figure 11-50 is pulled up in the idle state.

There is a guard interval after a character is transferred. During the entire guard interval, I/O (SCI\_DATA) is in the high impedance state, and the SCI and smart card are in data RX state. If the RX end detects that the received data is incorrect (for example, there is a parity error), it pulls down the I/O state by one or two ETUs. After receiving the error indicator, the TX end retransmits the previous byte. This function is available only when the handshake mechanism between the SCI and the smart card is enabled.

The guard interval is configured in **SCI\_CHGUARD[scichguard]** and its unit is ETU. The SCI supports the data transfer without transmitting the parity bit, which expands the compatibility of future protocols. The function can be implemented by setting **SCI\_CR0[paritybit]** to 0.



## 11.9.4 Operating Mode

### 11.9.4.1 Interaction Between the SCI and a Smart Card

The interaction between the SCI and a smart card is as follows:

- Step 1** Initialize the SCI module. The smart card clock, initial operating mode of the SCI, and interrupt enable bits need to be configured by configuring registers including [SCI\\_CR0](#), [SCI\\_CR1](#), [SCI\\_CLKICC](#), [SCI\\_VALUE](#), [SCI\\_BAUD](#), [SCI\\_STABLE](#), threshold time registers, and [SCI\\_IMSC](#).
- Step 2** Insert a smart card. Then [SCI\\_DETECT](#) is valid. The SCI reports an interrupt after detecting card insertion.
- Step 3** Software writes 1 to [SCI\\_CR2](#)[startup]. The SCI resets and activates the smart card. See [Figure 11-47](#).
- Step 4** The smart card sends an ATR to start information exchange between the smart card and the SCI.
- Step 5** Software reads data from the RX FIFO and reconfigures the SCI parameters based on the read ATR information. The parameters include the ETU, smart card clock rate, and forward convention or inverse convention.
- Step 6** The SCI and the smart card exchange data in asynchronous half-duplex mode. Data can be written to the TX FIFO only when software switches to the TX mode. Data can be read to the RX FIFO only when software switches to the RX mode. For details about the character structure, see "[Character Transfer Structure](#)."
- Step 7** The SCI sends a release timing (see [Figure 11-48](#)) to release the smart card after data transfer is complete.

----End

### 11.9.4.2 Configurations of the Smart Card Clock and ETU



#### CAUTION

- During ATR reception, the frequency of the smart card clock ranges from 1 MHz to - 5MHz and the ETU is  $372/F_{SCL\_CLK}$  according to the T0 and T1 protocols. According to the T14 protocol, the smart card clock is 6 MHz at the maximum and the ETU is  $620/F_{SCL\_CLK}$ .
- After the ATR is received, the SCI needs to configure the ETU based on the F and D dividers in the ART:  $ETU = F/F_{SCL\_CLK} \times 1/D$ .
- [SCI\\_VALUE](#) and [SCI\\_BAUD](#) must be configured based on the following formula:  
$$(1 + Baud) \times Value/F_{REFCLK} = F/F_{SCL\_CLK} \times 1/D$$

For details about how to configure the smart card clock, see section [11.9.4.1 "Interaction Between the SCI and a Smart Card"](#).

The ETU is configured in two phases:

- Phase 1: Step 1 in section [11.9.4.1 "Interaction Between the SCI and a Smart Card"](#), including the ETU configuration before the ATR timing is received.



- Phase 2: Step 5 in section [11.9.4.1 "Interaction Between the SCI and a Smart Card,"](#) including the ETU reconfiguration after the parameters D and F in the ATR timing are received.

The frequency of SCI\_CLK and level width of [SCI\\_DATA](#) can be configured by configuring registers. For details about the formula for calculating the values, see the descriptions of [SCI\\_VALUE](#) and [SCI\\_CLKICC](#).

#### NOTE

In the formulas described in this section, FSCI\_CLK is the frequency of SCI\_CLK and its unit is MHz.

The ETU is calculated as follows:  $ETU = (1 + \text{Baud}) \times \text{Value}/F_{REFCLK}$ . For details, see the description of [SCI\\_VALUE](#).

## 11.9.5 Register Summary

Hi3796M V100 has one SCI unit.

[Table 11-18](#) describes SCI registers.

**Table 11-18** Summary of SCI registers (base address: 0xF8B1\_8000)

| Offset Address | Register      | Description                                                   | Page |
|----------------|---------------|---------------------------------------------------------------|------|
| 0x0000         | SCI_DATA      | SCI data register                                             |      |
| 0x0004         | SCI_CR0       | SCI control register 0                                        |      |
| 0x0008         | SCI_CR1       | SCI control register 1                                        |      |
| 0x000C         | SCI_CR2       | SCI control register 2                                        |      |
| 0x0010         | SCI_CLKICC    | Smart card clock frequency register                           |      |
| 0x0014         | SCI_VALUE     | SCI_BAUD cycle count register in an ETU                       |      |
| 0x0018         | SCI_BAUD      | Baud rate clock frequency divider register                    |      |
| 0x001C         | SCI_TIDE      | TX or RX FIFO overflow threshold register                     |      |
| 0x0024         | SCI_STABLE    | Smart card insertion stable time register                     |      |
| 0x0028         | SCI_ATIME     | Smart card activation time register                           |      |
| 0x002C         | SCI_DTIME     | Smart card release time register                              |      |
| 0x0030         | SCI_ATRSTIME  | ATR RX wait time threshold register                           |      |
| 0x0034         | SCI_ATRDTIME  | ATR RX time threshold register                                |      |
| 0x0038         | SCI_STOPTIME  | Clock stop time register                                      |      |
| 0x003C         | SCI_STARTTIME | Smart card clock recovery time register                       |      |
| 0x0040         | SCI_RETRY     | TX or RX retry times register                                 |      |
| 0x0044         | SCI_CHTIMELS  | Lower 16-bit character RX interval timeout threshold register |      |



| Offset Address | Register       | Description                                                   | Page |
|----------------|----------------|---------------------------------------------------------------|------|
| 0x0048         | SCI_CHTIMEMS   | Upper 16-bit character RX interval timeout threshold register |      |
| 0x004C         | SCI_BLKTIMELS  | Lower 16-bit block RX interval timeout threshold register     |      |
| 0x0050         | SCI_BLKTIMEMS  | Upper 16-bit block RX interval timeout threshold register     |      |
| 0x0054         | SCI_CHGUARD    | Character guard interval register                             |      |
| 0x0058         | SCI_BLKGUARD   | Block guard interval register                                 |      |
| 0x005C         | SCI_RXTIME     | RX FIFO read timeout threshold register                       |      |
| 0x0060         | SCI_FIFOSTATUS | FIFO status register                                          |      |
| 0x0064         | SCI_TXCOUNT    | TX FIFO data count register                                   |      |
| 0x0068         | SCI_RXCOUNT    | RX FIFO data count register                                   |      |
| 0x006C         | SCI_IMSC       | Interrupt mask register                                       |      |
| 0x0070         | SCI_RIS        | Raw interrupt register                                        |      |
| 0x0074         | SCI_MIS        | Masked interrupt register                                     |      |
| 0x0078         | SCI_ICR        | Interrupt clear register                                      |      |
| 0x007C         | SCI_SYNCACT    | Activation register in sync mode                              |      |
| 0x0080         | SCI_SYNCTX     | TX clock and data stream register in sync mode                |      |
| 0x0084         | SCI_SYNCRX     | RX clock and data stream register in sync mode                |      |

## 11.9.6 Register Description

### SCI\_DATA

SCI\_DATA is an SCI data register. It is used to transmit or receive characters and serves as the data interface between the SCI and software.

The software can write to the register only after [SCI\\_CR1\[mode\]](#) is set to 1. If [SCI\\_CR1\[mode\]](#) is set to 0, writing to this register has no effect.



| Offset Address |        |          |    |    |                                                                                                                                                                                                                                     |          |   |   |        | Register Name |        |   |   |   |   | Total Reset Value |  |  |  |  |  |
|----------------|--------|----------|----|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---|---|--------|---------------|--------|---|---|---|---|-------------------|--|--|--|--|--|
| Bit            | 0x0000 |          |    |    |                                                                                                                                                                                                                                     | SCI_DATA |   |   |        |               | 0x0000 |   |   |   |   |                   |  |  |  |  |  |
| Name           | 15     | 14       | 13 | 12 | 11                                                                                                                                                                                                                                  | 10       | 9 | 8 | 7      | 6             | 5      | 4 | 3 | 2 | 1 | 0                 |  |  |  |  |  |
| reserved       |        |          |    |    |                                                                                                                                                                                                                                     |          |   |   | parity | scidata       |        |   |   |   |   |                   |  |  |  |  |  |
| Reset          | 0      | 0        | 0  | 0  | 0                                                                                                                                                                                                                                   | 0        | 0 | 0 | 0      | 0             | 0      | 0 | 0 | 0 | 0 | 0                 |  |  |  |  |  |
| Bits           | Access | Name     |    |    | Description                                                                                                                                                                                                                         |          |   |   |        |               |        |   |   |   |   |                   |  |  |  |  |  |
| [15:9]         | -      | reserved |    |    | Reserved                                                                                                                                                                                                                            |          |   |   |        |               |        |   |   |   |   |                   |  |  |  |  |  |
| [8]            | RO     | parity   |    |    | Parity check error flag<br><br>This bit is transmitted with data during data transmission. During data reception, software checks whether parity check is correct based on the value of this bit.<br><br>0: correct<br>1: incorrect |          |   |   |        |               |        |   |   |   |   |                   |  |  |  |  |  |
| [7:0]          | RW     | scidata  |    |    | 8-bit data to be read or written                                                                                                                                                                                                    |          |   |   |        |               |        |   |   |   |   |                   |  |  |  |  |  |

## SCI\_CR0

SCI\_CR0 is SCI control register 0. It is used to control the information such as clock enable, parity check, transfer handshake, and transfer bit definition.



### CAUTION

- SCI\_CR0[paritybit] controls whether to enable the parity check function during data transmission or reception. When this bit is set to 0, the received or transmitted frame does not contain the parity bit. According to the T0 or T1 protocol, this bit must be set to 1.
- SCI\_CR0[clkdis] and SCI\_CR0[clkval] control whether to enable the smart card clock and configure the state of the clock pin after the clock is disabled.
- SCI\_CR0[rxnak] and SCI\_CR0[txnak] control whether to enable the handshake mechanisms between the SCI and the smart card. A handshake is implemented when the RX end pulls down the data line (I/O) to request the TX end to retransmit characters after detecting a parity check error in the data sent from the TX end. The handshake mechanisms for data transmission and reception are separately enabled. The maximum retry count during data transmission or reception is defined by [SCI\\_RETRY](#). During ATR reception, character retransmission is not allowed; therefore, the handshake mechanism must be disabled by setting the corresponding TX or RX control bit to 0.
- SCI\_CR0[rxparity] and SCI\_CR0[txparity] control the parity check mode during data reception and transmission respectively.



According to the direct convention, the low level of the data line (I/O) indicates logic 0 and the LSB of data is after the start bit of a frame. If SCI\_CR0 bit[1:0] is set to 0b00, the direct convention is selected.

According to the inverse convention, the low level of the data line (I/O) indicates logic 1 and the MSB of data is after the start bit of a frame. If SCI\_CR0 bit[1:0] is set to 0b11, the inverse convention is selected.

**NOTE**

The character bit sequence and inversion of the data and parity bits can be separately configured. These features enable the SCI to support non-standard protocols (non-direct convention or non-inverse convention).

Before the start TS character of the ATR is received, SCI\_CR0 bit[1:0] must be set to 0b00.

|         | Offset Address |            |    |                                                                                                                                                  |    | Register Name |           |           |        |        | Total Reset Value |          |       |          |       |       |
|---------|----------------|------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------|-----------|-----------|--------|--------|-------------------|----------|-------|----------|-------|-------|
|         | 0x0004         |            |    |                                                                                                                                                  |    | SCI_CR0       |           |           |        |        | 0x0000            |          |       |          |       |       |
| Bit     | 15             | 14         | 13 | 12                                                                                                                                               | 11 | 10            | 9         | 8         | 7      | 6      | 5                 | 4        | 3     | 2        | 1     | 0     |
| Name    | reserved       |            |    |                                                                                                                                                  |    | detect_inv    | vccen_inv | paritybit | clkval | clkdis | rxnak             | rxparity | txnak | txparity | order | sense |
| Reset   | 0              | 0          | 0  | 0                                                                                                                                                | 0  | 0             | 0         | 0         | 0      | 0      | 0                 | 0        | 0     | 0        | 0     | 0     |
| Bits    | Access         | Name       |    | Description                                                                                                                                      |    |               |           |           |        |        |                   |          |       |          |       |       |
| [15:11] | -              | reserved   |    | Reserved                                                                                                                                         |    |               |           |           |        |        |                   |          |       |          |       |       |
| [10]    | RW             | detect_inv |    | Valid level for the detected input signal<br>0: active high<br>1: active low                                                                     |    |               |           |           |        |        |                   |          |       |          |       |       |
| [9]     | RW             | vccen_inv  |    | Valid level for the vccen output signal<br>0: active high<br>1: active low                                                                       |    |               |           |           |        |        |                   |          |       |          |       |       |
| [8]     | RW             | paritybit  |    | Parity bit transfer enable<br>0: disabled<br>1: enabled                                                                                          |    |               |           |           |        |        |                   |          |       |          |       |       |
| [7]     | RW             | clkval     |    | Status of the smart card clock when the clock stops<br>0: The smart card clock retains low level.<br>1: The smart card clock retains high level. |    |               |           |           |        |        |                   |          |       |          |       |       |
| [6]     | RW             | clkdis     |    | Clock start/stop control<br>0: The clock starts.<br>1: The clock stops.                                                                          |    |               |           |           |        |        |                   |          |       |          |       |       |



|     |    |          |                                                                                                                                                                                                                             |
|-----|----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5] | RW | rxnak    | Behavior control in RX mode<br>0: The SCI does not pull down the I/O line when detecting a parity error.<br>1: The SCI pulls down the I/O line when detecting a parity error.                                               |
| [4] | RW | rxparity | Parity check mode control in RX mode<br>0: even parity check<br>1: odd parity check                                                                                                                                         |
| [3] | RW | txnak    | Behavior control in TX mode<br>0: The SCI does not detect whether the receiver pulls down the I/O line.<br>1: The SCI detects whether the receiver pulls down the I/O line.                                                 |
| [2] | RW | txparity | Parity check mode control in TX mode<br>0: even parity check<br>1: odd parity check                                                                                                                                         |
| [1] | RW | order    | Character bit sequence<br>0: The LSB is transmitted or received after the start bit.<br>1: The MSB is transmitted or received after the start bit.                                                                          |
| [0] | RW | sense    | Whether to detect the data and parity bits on the I/O line after inversion<br>0: The SCI directly detects data and parity bits on the I/O line.<br>1: The SCI detects data and parity bits on the I/O line after inversion. |

## SCI\_CR1

SCI\_CR1 is SCI control register 1. It is used to control the transfer mode, TX/RX mode, block timeout, and ATR timeout of synchronous and asynchronous cards.

| Offset Address |          | Register Name |    |             |    |    |   |   |   |   |   |   |         |         | Total Reset Value |       |      |       |       |
|----------------|----------|---------------|----|-------------|----|----|---|---|---|---|---|---|---------|---------|-------------------|-------|------|-------|-------|
| 0x0008         |          | SCI_CR1       |    |             |    |    |   |   |   |   |   |   |         |         | 0x0000            |       |      |       |       |
| Bit            | 15       | 14            | 13 | 12          | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3       | 2       | 1                 | 0     |      |       |       |
| Name           | reserved |               |    |             |    |    |   |   |   |   |   |   | syncard | exdbnce | bgtcn             | clkz1 | mode | blkcn | atrdn |
| Reset          | 0        | 0             | 0  | 0           | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0       | 0       | 0                 | 0     | 0    |       |       |
| Bits           | Access   | Name          |    | Description |    |    |   |   |   |   |   |   |         |         |                   |       |      |       |       |
| [15:7]         | -        | reserved      |    | Reserved    |    |    |   |   |   |   |   |   |         |         |                   |       |      |       |       |



|     |    |          |                                                                                                                                                                                                                                                 |
|-----|----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | RW | synccard | Operation mode of the smart card<br>0: async mode<br>1: sync mode                                                                                                                                                                               |
| [5] | RW | exdbnce  | Debounce wait counter select after the card is inserted and stable.<br>For details, see the description of SCI_STABLE.<br>0: The entire internal debounce counter is used.<br>1: The non-programmable part of the internal counter is bypassed. |
| [4] | RW | bgtcn    | Block guard counter enable for the block guard mechanism<br>0: disabled<br>1: enabled                                                                                                                                                           |
| [3] | RW | clkz1    | SCI_CLK pin output configuration<br>0: CMOS output<br>1: OD output                                                                                                                                                                              |
| [2] | RW | mode     | TX/RX mode<br>0: RX mode<br>1: TX mode                                                                                                                                                                                                          |
| [1] | RW | blkcn    | Block timeout count mechanism enable<br>0: disabled<br>1: enabled                                                                                                                                                                               |
| [0] | RW | atrden   | ATR timeout count mechanism enable<br>0: disabled<br>1: enabled                                                                                                                                                                                 |

## SCI\_CR2

SCI\_CR2 is SCI control register 2. After a value is written to a specific bit of SCI\_CR2, the SCI activates, releases, or soft-resets the smart card. When the SCI is releasing the smart card, write operations on this register are ignored. In other cases, writing 1 to SCI\_CR2[finish] enables the SCI to immediately send a card release timing.



### CAUTION

- The software writes to SCI\_CR2 only in appropriate card operation phases. An inappropriate write may result in an unexpected result.
- The smart card can be soft-reset by software only after the card is activated.



|        | Offset Address |          |    |                                                                                                                                                                                                      |    |    |   |   |   |   | Register Name |   |        |        | Total Reset Value |   |  |  |
|--------|----------------|----------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|---|---|---|---------------|---|--------|--------|-------------------|---|--|--|
|        | 0x000C         |          |    |                                                                                                                                                                                                      |    |    |   |   |   |   | SCI_CR2       |   |        |        | 0x0000            |   |  |  |
| Bit    | 15             | 14       | 13 | 12                                                                                                                                                                                                   | 11 | 10 | 9 | 8 | 7 | 6 | 5             | 4 | 3      | 2      | 1                 | 0 |  |  |
| Name   | reserved       |          |    |                                                                                                                                                                                                      |    |    |   |   |   |   |               |   | wreset | finish | startup           |   |  |  |
| Reset  | 0              | 0        | 0  | 0                                                                                                                                                                                                    | 0  | 0  | 0 | 0 | 0 | 0 | 0             | 0 | 0      | 0      | 0                 | 0 |  |  |
| Bits   | Access         | Name     |    | Description                                                                                                                                                                                          |    |    |   |   |   |   |               |   |        |        |                   |   |  |  |
| [15:3] | -              | reserved |    | Reserved                                                                                                                                                                                             |    |    |   |   |   |   |               |   |        |        |                   |   |  |  |
| [2]    | WO             | wreset   |    | Soft reset on the smart card<br>0: invalid<br>1: soft-reset<br>Note: This bit can be written only after the activation timing is transmitted. Otherwise, writing to this bit has no effect.          |    |    |   |   |   |   |               |   |        |        |                   |   |  |  |
| [1]    | WO             | finish   |    | Release operation on the smart card<br>0: invalid<br>1: released<br>Note: This bit can be written only after the card reader detects a smart card. Otherwise, writing to this bit has no effect.     |    |    |   |   |   |   |               |   |        |        |                   |   |  |  |
| [0]    | WO             | startup  |    | Activation operation on the smart card<br>0: invalid<br>1: activated<br>Note: This bit can be written only after the card reader detects a smart card. Otherwise, writing to this bit has no effect. |    |    |   |   |   |   |               |   |        |        |                   |   |  |  |

## SCI\_CLKICC

SCI\_CLKICC is a smart card clock frequency register. It defines the clock divider of the external smart card. The frequency of the smart card clock is calculated as follows:  $F_{SCI\_CLK} = F_{REFCLK}/2 \times (clkicc + 1)$ .  $F_{SCI\_CLK}$  indicates the clock frequency,  $F_{REFCLK}$  indicates the frequency of the reference clock, and  $clkicc$  is the value configured in SCI\_CLKICC[clkicc].

|        | Offset Address |          |    |             |    |    |   |   |   |   | Register Name |   |   |   | Total Reset Value |   |  |  |
|--------|----------------|----------|----|-------------|----|----|---|---|---|---|---------------|---|---|---|-------------------|---|--|--|
|        | 0x0010         |          |    |             |    |    |   |   |   |   | SCI_CLKICC    |   |   |   | 0x0000            |   |  |  |
| Bit    | 15             | 14       | 13 | 12          | 11 | 10 | 9 | 8 | 7 | 6 | 5             | 4 | 3 | 2 | 1                 | 0 |  |  |
| Name   | reserved       |          |    |             |    |    |   |   |   |   | clkicc        |   |   |   |                   |   |  |  |
| Reset  | 0              | 0        | 0  | 0           | 0  | 0  | 0 | 0 | 0 | 0 | 0             | 0 | 0 | 0 | 0                 | 0 |  |  |
| Bits   | Access         | Name     |    | Description |    |    |   |   |   |   |               |   |   |   |                   |   |  |  |
| [15:8] | -              | reserved |    | Reserved    |    |    |   |   |   |   |               |   |   |   |                   |   |  |  |



|       |    |        |                                                                                                                 |
|-------|----|--------|-----------------------------------------------------------------------------------------------------------------|
| [7:0] | RW | clkicc | Divider of the smart card clock (obtained by dividing the reference clock frequency). Its value range is 0–255. |
|-------|----|--------|-----------------------------------------------------------------------------------------------------------------|

## SCI\_VALUE

SCI\_VALUE is an SCI\_BAUD cycle count register in an ETU. Its value range is 5–255 and is used to calculate the ETU as follows: ETU = (1 + baud) x value/FREFCLK. FREFCLK is the frequency of the reference clock, baud is the value configured in SCI\_BAUD[baud], and value is the value configured in SCI\_VALUE[value].

|        | Offset Address |          |    |    |                                     |    |   |   | Register Name |   |   |   |   |   |   |       | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|----------|----|----|-------------------------------------|----|---|---|---------------|---|---|---|---|---|---|-------|-------------------|--|--|--|--|--|--|--|
|        | 0x0014         |          |    |    |                                     |    |   |   | SCI_VALUE     |   |   |   |   |   |   |       | 0x0000            |  |  |  |  |  |  |  |
| Bit    | 15             | 14       | 13 | 12 | 11                                  | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0     |                   |  |  |  |  |  |  |  |
| Name   | reserved       |          |    |    |                                     |    |   |   |               |   |   |   |   |   |   | value |                   |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0  | 0                                   | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 | 0     |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    |    | Description                         |    |   |   |               |   |   |   |   |   |   |       |                   |  |  |  |  |  |  |  |
| [15:8] | -              | reserved |    |    | Reserved                            |    |   |   |               |   |   |   |   |   |   |       |                   |  |  |  |  |  |  |  |
| [7:0]  | RW             | value    |    |    | Number of SCI_BAUD cycles in an ETU |    |   |   |               |   |   |   |   |   |   |       |                   |  |  |  |  |  |  |  |

## SCI\_BAUD

SCI\_BAUD is a baud rate clock divider register. It is used to calculate the ETU and its value range is 0x1–0xFFFF. For details about how to calculate the ETU, see the description of [SCI\\_BAUD](#).

|        | Offset Address |      |    |    |                                |    |   |   | Register Name |   |   |   |   |   |   |      | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|------|----|----|--------------------------------|----|---|---|---------------|---|---|---|---|---|---|------|-------------------|--|--|--|--|--|--|--|
|        | 0x0018         |      |    |    |                                |    |   |   | SCI_BAUD      |   |   |   |   |   |   |      | 0x0000            |  |  |  |  |  |  |  |
| Bit    | 15             | 14   | 13 | 12 | 11                             | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0    |                   |  |  |  |  |  |  |  |
| Name   | baud           |      |    |    |                                |    |   |   |               |   |   |   |   |   |   | baud |                   |  |  |  |  |  |  |  |
| Reset  | 0              | 0    | 0  | 0  | 0                              | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 | 0    |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name |    |    | Description                    |    |   |   |               |   |   |   |   |   |   |      |                   |  |  |  |  |  |  |  |
| [15:0] | RW             | baud |    |    | Clock divider of the baud rate |    |   |   |               |   |   |   |   |   |   |      |                   |  |  |  |  |  |  |  |

## SCI\_TIDE

SCI\_TIDE is a TX/RX FIFO overflow threshold register.



### NOTE

The characters in the TX FIFO are removed only after data is successfully transmitted.



|         | Offset Address |          |    |    |                                                                                                                                                                                             | Register Name |   |   |   |        | Total Reset Value |   |   |   |   |   |
|---------|----------------|----------|----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---|---|---|--------|-------------------|---|---|---|---|---|
|         | 0x001C         |          |    |    |                                                                                                                                                                                             | SCI_TIDE      |   |   |   |        | 0x0000            |   |   |   |   |   |
| Bit     | 15             | 14       | 13 | 12 | 11                                                                                                                                                                                          | 10            | 9 | 8 | 7 | 6      | 5                 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved       |          |    |    | rxtide                                                                                                                                                                                      |               |   |   |   | txtide |                   |   |   |   |   |   |
| Reset   | 0              | 0        | 0  | 0  | 0                                                                                                                                                                                           | 0             | 0 | 0 | 0 | 0      | 0                 | 0 | 0 | 0 | 0 |   |
| Bits    | Access         | Name     |    |    | Description                                                                                                                                                                                 |               |   |   |   |        |                   |   |   |   |   |   |
| [15:12] | -              | reserved |    |    | Reserved                                                                                                                                                                                    |               |   |   |   |        |                   |   |   |   |   |   |
| [11:6]  | RW             | rxtide   |    |    | Value for triggering the SCIRXTIDEINTR interrupt<br>When the number of characters in the RX FIFO is greater than or equal to SCI_TIDE[rxtide], the RX FIFO overflow interrupt is triggered. |               |   |   |   |        |                   |   |   |   |   |   |
| [5:0]   | RW             | txtide   |    |    | Value for triggering the SCI TXTIDEINTR interrupt<br>When the number of characters in the TX FIFO is less than or equal to SCI_TIDE[txtide], the TX FIFO overflow interrupt is triggered.   |               |   |   |   |        |                   |   |   |   |   |   |

## SCI\_STABLE

SCI\_STABLE is a smart card insertion stable time register. After the SCI detects that the SCI\_DETECT signal is valid, the signal must retain valid for the period (in second) specified by T<sub>STABLE</sub> that corresponds to the value defined in the SCI\_STABLE register. After the period specified by T<sub>STABLE</sub> has elapsed, an interrupt is triggered, indicating that the smart card has been properly inserted. The value of T<sub>STABLE</sub> varies according to counter:

- When the entire internal debounce counter is selected (that is, SCI\_CR1[exdbnse] is set to 0), T<sub>STABLE</sub> is calculated as follows: T<sub>STABLE</sub> = (1 + Stable) x 65535 x T<sub>REFCLK</sub>. T<sub>REFCLK</sub> indicates the SCI reference clock cycle (1/48 MHz), and stable is the value configured in SCI\_STABLE[stable].
- When the non-programmable part of the internal debounce counter is bypassed (that is, SCI\_CR1[exdbnse] is set to 1), T<sub>STABLE</sub> is calculated as follows: T<sub>STABLE</sub> = Stable x T<sub>REFCLK</sub>.

|         | Offset Address |          |    |    |                                                              | Register Name |   |   |   |   | Total Reset Value |   |   |   |   |   |
|---------|----------------|----------|----|----|--------------------------------------------------------------|---------------|---|---|---|---|-------------------|---|---|---|---|---|
|         | 0x0024         |          |    |    |                                                              | SCI_STABLE    |   |   |   |   | 0x0000            |   |   |   |   |   |
| Bit     | 15             | 14       | 13 | 12 | 11                                                           | 10            | 9 | 8 | 7 | 6 | 5                 | 4 | 3 | 2 | 1 | 0 |
| Name    | reserved       |          |    |    |                                                              | stable        |   |   |   |   |                   |   |   |   |   |   |
| Reset   | 0              | 0        | 0  | 0  | 0                                                            | 0             | 0 | 0 | 0 | 0 | 0                 | 0 | 0 | 0 | 0 |   |
| Bits    | Access         | Name     |    |    | Description                                                  |               |   |   |   |   |                   |   |   |   |   |   |
| [15:10] | -              | reserved |    |    | Reserved                                                     |               |   |   |   |   |                   |   |   |   |   |   |
| [9:0]   | RW             | stable   |    |    | Duration during which the card detection signal is held high |               |   |   |   |   |                   |   |   |   |   |   |



## SCI\_ATIME

SCI\_ATIME is a smart card activation time register. SCI\_ATIME[etime] corresponds to SCIAETIME in [Figure 11-47](#) and indicates the duration of each of the three phases involved in card reset and activation.

### NOTE

SCI\_ATIME[etime] must be at least 40,000 smart card clock (SCI\_CLK) cycles to ensure card reset. SCI\_ATIME[etime] must also ensure power stability for the smart card.

| Offset Address |        |    |       |    |    |                                                                                                                                                                                                  |   |   |   | Register Name |   |   |   |   |   | Total Reset Value |  |  |  |  |  |
|----------------|--------|----|-------|----|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---------------|---|---|---|---|---|-------------------|--|--|--|--|--|
| 0x0028         |        |    |       |    |    |                                                                                                                                                                                                  |   |   |   | SCI_ATIME     |   |   |   |   |   | 0x0000            |  |  |  |  |  |
| Bit            | 15     | 14 | 13    | 12 | 11 | 10                                                                                                                                                                                               | 9 | 8 | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0                 |  |  |  |  |  |
| Name           |        |    |       |    |    |                                                                                                                                                                                                  |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| Reset          |        |    |       |    |    |                                                                                                                                                                                                  |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| Bits           | Access |    | Name  |    |    | Description                                                                                                                                                                                      |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| [15:0]         | RW     |    | etime |    |    | Duration (SCI_CLK cycle count) of each of the three phases involved in the card activation timing. For details about the timing for resetting the smart card, see <a href="#">Figure 11-47</a> . |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |

## SCI\_DTIME

SCI\_DTIME is a smart card release time register. SCI\_DTIME[dtime] corresponds to SCIDTIME in [Figure 11-48](#). It indicates the duration of each of the three phases involved in card release.

| Offset Address |        |    |       |    |    |                                                                                                                                                                                                     |   |   |   | Register Name |   |   |   |   |   | Total Reset Value |  |  |  |  |  |
|----------------|--------|----|-------|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---------------|---|---|---|---|---|-------------------|--|--|--|--|--|
| 0x002C         |        |    |       |    |    |                                                                                                                                                                                                     |   |   |   | SCI_DTIME     |   |   |   |   |   | 0x0000            |  |  |  |  |  |
| Bit            | 15     | 14 | 13    | 12 | 11 | 10                                                                                                                                                                                                  | 9 | 8 | 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0                 |  |  |  |  |  |
| Name           |        |    |       |    |    |                                                                                                                                                                                                     |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| Reset          |        |    |       |    |    |                                                                                                                                                                                                     |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| Bits           | Access |    | Name  |    |    | Description                                                                                                                                                                                         |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |
| [15:0]         | RW     |    | dtime |    |    | Duration (SCI reference clock cycle) of each of the three phases involved in the card release timing. For details about the timing for releasing the smart card, see <a href="#">Figure 11-48</a> . |   |   |   |               |   |   |   |   |   |                   |  |  |  |  |  |

## SCI\_ATRSTIME

SCI\_ATRSTIME is an ATR RX start time threshold register. SCI\_ATRSTIME[dtime] corresponds to SCIAINTRSTIME in [Figure 11-47](#). Based on the smart card clock, the register defines the time threshold from finishing smart card reset to starting to receive the first ATR character. If waiting for the ATR RX start signal times out, an interrupt is triggered and [SCI\\_RIS](#)[atrstoutim] is set to 1.



SCI\_ATRSTIME[atrstime] must be set to 40,000 SCI\_CLK cycles by software.

| Offset Address |          |          |                                                              |    |    |    |   |   |   | Register Name |   |   |   |   | Total Reset Value |   |  |
|----------------|----------|----------|--------------------------------------------------------------|----|----|----|---|---|---|---------------|---|---|---|---|-------------------|---|--|
| Bit            | 15       | 14       | 13                                                           | 12 | 11 | 10 | 9 | 8 | 7 | 6             | 5 | 4 | 3 | 2 | 1                 | 0 |  |
| Name           | atrstime |          |                                                              |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |
| Reset          | 0        | 0        | 0                                                            | 0  | 0  | 0  | 0 | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0                 |   |  |
| Bits           | Access   | Name     | Description                                                  |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |
| [15:0]         | RW       | atrstime | Timeout threshold (SCI_CLK cycle) for starting ATR reception |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |

## SCI\_ATRDTIME

SCI\_ATRDTIME is an ATR RX time threshold register. If the duration from receiving the first ATR character to receiving the last one exceeds the duration (in ETU) defined in this register, an interrupt is triggered and SCI\_RIS[atrdtoutris] is set to 1.

### NOTE

- Before using this register, set SCI\_CR1[atrden] to 1 to enable the timeout count mechanism.
- According to the protocol, it is recommended that this register be set to 19,200 ETUs (0x4B00).

| Offset Address |          |          |                                                                                           |    |    |    |   |   |   | Register Name |   |   |   |   | Total Reset Value |   |  |
|----------------|----------|----------|-------------------------------------------------------------------------------------------|----|----|----|---|---|---|---------------|---|---|---|---|-------------------|---|--|
| Bit            | 15       | 14       | 13                                                                                        | 12 | 11 | 10 | 9 | 8 | 7 | 6             | 5 | 4 | 3 | 2 | 1                 | 0 |  |
| Name           | atrdtime |          |                                                                                           |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |
| Reset          | 0        | 0        | 0                                                                                         | 0  | 0  | 0  | 0 | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0                 |   |  |
| Bits           | Access   | Name     | Description                                                                               |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |
| [15:0]         | RW       | atrdtime | ATR RX timeout threshold (in ETU), counting from the start bit of the first ATR character |    |    |    |   |   |   |               |   |   |   |   |                   |   |  |

## SCI\_STOPTIME

SCI\_STOPTIME is a clock stop time register. When the smart card clock stops, it becomes invalid after the time defined in SCI\_STOPTIME (SCI\_CLK cycles) has elapsed. Then an interrupt is triggered, and SCI\_RIS[clkstpris] is set to 1.

According to the protocol, the minimum clock stop time is 1860 SCI\_CLK cycles, that is, when SCI\_STOPTIME[stoptime] is set to 0x744.



| Offset Address |          |          |    |    |                                                         |    |   |   |   |   |   | Register Name | Total Reset Value |   |   |   |
|----------------|----------|----------|----|----|---------------------------------------------------------|----|---|---|---|---|---|---------------|-------------------|---|---|---|
| 0x0038         |          |          |    |    |                                                         |    |   |   |   |   |   | SCI_STOPTIME  | 0x0000            |   |   |   |
| Bit            | 15       | 14       | 13 | 12 | 11                                                      | 10 | 9 | 8 | 7 | 6 | 5 | 4             | 3                 | 2 | 1 | 0 |
| Name           | reserved |          |    |    | stoptime                                                |    |   |   |   |   |   |               |                   |   |   |   |
| Reset          | 0        | 0        | 0  | 0  | 0                                                       | 0  | 0 | 0 | 0 | 0 | 0 | 0             | 0                 | 0 | 0 | 0 |
| Bits           | Access   | Name     |    |    | Description                                             |    |   |   |   |   |   |               |                   |   |   |   |
| [15:12]        | -        | reserved |    |    | Reserved                                                |    |   |   |   |   |   |               |                   |   |   |   |
| [11:0]         | RW       | stoptime |    |    | Time (SCI_CLK cycles) for stopping the smart card clock |    |   |   |   |   |   |               |                   |   |   |   |

## SCI\_STARTTIME

SCI\_STARTTIME is a smart card clock recovery time register. If clock recovery is enabled, data can be transferred between the smart card and the SCI after the time (SCI\_CLK cycles) defined in SCI\_STARTTIME has elapsed. Then, an interrupt is triggered, and [SCI\\_RIS\[clkactris\]](#) is set to 1.

According to the protocol, the minimum clock recovery time is 700 SCI\_CLK cycles, that is, when SCI\_STARTTIME[starttimr] is set to 0x2BC.

| Offset Address |          |           |    |    |                                                                                                                       |    |   |   |   |   |   | Register Name | Total Reset Value |   |   |   |
|----------------|----------|-----------|----|----|-----------------------------------------------------------------------------------------------------------------------|----|---|---|---|---|---|---------------|-------------------|---|---|---|
| 0x003C         |          |           |    |    |                                                                                                                       |    |   |   |   |   |   | SCI_STARTTIME | 0x0000            |   |   |   |
| Bit            | 15       | 14        | 13 | 12 | 11                                                                                                                    | 10 | 9 | 8 | 7 | 6 | 5 | 4             | 3                 | 2 | 1 | 0 |
| Name           | reserved |           |    |    | starttime                                                                                                             |    |   |   |   |   |   |               |                   |   |   |   |
| Reset          | 0        | 0         | 0  | 0  | 0                                                                                                                     | 0  | 0 | 0 | 0 | 0 | 0 | 0             | 0                 | 0 | 0 | 0 |
| Bits           | Access   | Name      |    |    | Description                                                                                                           |    |   |   |   |   |   |               |                   |   |   |   |
| [15:12]        | -        | reserved  |    |    | Reserved                                                                                                              |    |   |   |   |   |   |               |                   |   |   |   |
| [11:0]         | RW       | starttime |    |    | Duration (SCI_CLK cycles) from starting the card clock to activating data transfer between the SCI and the smart card |    |   |   |   |   |   |               |                   |   |   |   |

## SCI\_RETRY

SCI\_RETRY is an RX/TX retry times register. It defines the allowed number of TX or RX retry times. The details are as follows:

- If SCI\_CR0[txnak] is enabled, the SCI checks whether the RX end identifies a parity error. SCI\_RETRY[rxretry] defines the maximum number of retry times after a parity error occurs. If the maximum number of retry times is exceeded, an interrupt is triggered and [SCI\\_RIS\[txerrris\]](#) is set to 1.
- If SCI\_CR0[rxnak] is enabled, the SCI checks whether a parity error occurs in the received data. SCI\_RETRY[txretry] defines the maximum number of retry times allowed after a parity error occurs. If the number is exceeded but the RX error still persists, [SCI\\_DATA\[parity\]](#) is set to 1.



|        | Offset Address |          |    |                                                                                  |    |    |   |   | Register Name |   |   |   | Total Reset Value |   |   |   |
|--------|----------------|----------|----|----------------------------------------------------------------------------------|----|----|---|---|---------------|---|---|---|-------------------|---|---|---|
|        | 0x0040         |          |    |                                                                                  |    |    |   |   | SCI_RETRY     |   |   |   | 0x0000            |   |   |   |
| Bit    | 15             | 14       | 13 | 12                                                                               | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3                 | 2 | 1 | 0 |
| Name   | reserved       |          |    |                                                                                  |    |    |   |   | rxretry       |   |   |   | txretry           |   |   |   |
| Reset  | 0              | 0        | 0  | 0                                                                                | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0                 | 0 | 0 | 0 |
| Bits   | Access         | Name     |    | Description                                                                      |    |    |   |   |               |   |   |   |                   |   |   |   |
| [15:6] | -              | reserved |    | Reserved                                                                         |    |    |   |   |               |   |   |   |                   |   |   |   |
| [5:3]  | RW             | rxretry  |    | Maximum number of RX retry times after a parity error occurs during reception    |    |    |   |   |               |   |   |   |                   |   |   |   |
| [2:0]  | RW             | txretry  |    | Maximum number of TX retry times after a parity error occurs during transmission |    |    |   |   |               |   |   |   |                   |   |   |   |

## SCI\_CHTIMELS

SCI\_CHTIMELS is a character RX interval timeout threshold lower 16-bit register.



### CAUTION

The SCI\_CHTIME register consists of the lower 16-bit SCI\_CHTIMELS register and the upper 16-bit SCI\_CHTIMEMS register. SCI\_CHTIME does not immediately take effect after software writes to SCI\_CHTIMEMS. It takes effect only after software writes to SCI\_CHTIMELS. Therefore, you need to configure the upper 16 bits and then the lower 16 bits of SCI\_CHTIME in sequence.

SCI\_CHTIMELS is a character RX interval timeout threshold lower 16-bit register.

SCI\_CHTIME defines the maximum time interval (in ETU) between the start edges of two consecutive characters received from the smart card. If the character RX interval times out, an interrupt is triggered and SCI\_RIS[chtoutris] is set to 1.

|        | Offset Address |          |    |                                                                                 |    |    |   |   | Register Name |   |   |   | Total Reset Value |   |   |   |
|--------|----------------|----------|----|---------------------------------------------------------------------------------|----|----|---|---|---------------|---|---|---|-------------------|---|---|---|
|        | 0x0044         |          |    |                                                                                 |    |    |   |   | SCI_CHTIMELS  |   |   |   | 0x0000            |   |   |   |
| Bit    | 15             | 14       | 13 | 12                                                                              | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3                 | 2 | 1 | 0 |
| Name   | chtimels       |          |    |                                                                                 |    |    |   |   |               |   |   |   |                   |   |   |   |
| Reset  | 0              | 0        | 0  | 0                                                                               | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0                 | 0 | 0 | 0 |
| Bits   | Access         | Name     |    | Description                                                                     |    |    |   |   |               |   |   |   |                   |   |   |   |
| [15:0] | RW             | chtimels |    | Lower 16 bits of the character RX interval timeout threshold register SCICHTIME |    |    |   |   |               |   |   |   |                   |   |   |   |



## SCI\_CHTIMEMS

SCI\_CHTIMEMS is a character RX interval timeout threshold upper 16-bit register.

|        | Offset Address |          |    |                                                                                 |    |    |   |   | Register Name |   |   |   |   |   |   |   | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|----------|----|---------------------------------------------------------------------------------|----|----|---|---|---------------|---|---|---|---|---|---|---|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x0048         |          |    |                                                                                 |    |    |   |   | SCI_CHTIMEMS  |   |   |   |   |   |   |   | 0x0000            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 15             | 14       | 13 | 12                                                                              | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | chtimems       |          |    |                                                                                 |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0        | 0  | 0                                                                               | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name     |    | Description                                                                     |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [15:0] | RW             | chtimems |    | Upper 16 bits of the character RX interval timeout threshold register SCICHTIME |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SCI\_BLKTIMELS

SCI\_BLKTIMELS is a block RX interval timeout threshold lower 16-bit register.



### CAUTION

The SCI\_BLKTIME register consists of the lower 16-bit SCI\_BLKTIMELS register and the upper 16-bit SCI\_BLKTIMEMS register. SCI\_BLKTIME does not immediately take effect after software writes to SCI\_BLKTIMEMS. It takes effect only after software writes to SCI\_BLKTIMELS. Therefore, you need to configure the upper 16 bits and then the lower 16 bits of SCI\_BLKTIME in sequence.

SCI\_BLKTIMELS is a block RX interval timeout threshold lower 16-bit register.

SCI\_BLKTIME defines the maximum block RX interval (in ETU). The interval is counted from the start edge of the last character that is transmitted to the smart card to the time when the first character returned from the smart card is received.

If the interval times out, an interrupt is triggered and SCI\_RIS[blkoutim] is set to 1.

|        | Offset Address |           |    |                                                                              |    |    |   |   | Register Name |   |   |   |   |   |   |   | Total Reset Value |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|----------------|-----------|----|------------------------------------------------------------------------------|----|----|---|---|---------------|---|---|---|---|---|---|---|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|        | 0x004C         |           |    |                                                                              |    |    |   |   | SCI_BLKTIMELS |   |   |   |   |   |   |   | 0x0000            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit    | 15             | 14        | 13 | 12                                                                           | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name   | blktimels      |           |    |                                                                              |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset  | 0              | 0         | 0  | 0                                                                            | 0  | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bits   | Access         | Name      |    | Description                                                                  |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| [15:0] | RW             | blktimels |    | Lower 16 bits of the block RX interval timeout threshold register SCIBLKTIME |    |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |



## **SCI\_BLKTIMEMS**

**SCI\_BLKTIMES** is a block RX interval timeout threshold upper 16-bit register.

SCI\_CHGUARD

**SCI\_CHGUARD** is a character guard interval register. It defines the minimum extra guard interval (in ETU) between the start edges of two consecutive characters when the SCI is transmitting characters to the smart card. The character guard interval depends on the global interface byte TC1 (obtained from the ATR timing) defined in the protocol.

| Offset Address |          | Register Name |                                   | Total Reset Value |                 |  |
|----------------|----------|---------------|-----------------------------------|-------------------|-----------------|--|
| 0x0054         |          | SCI_CHGUARD   |                                   | 0x0000            |                 |  |
| Bit            | 15 14    | 13 12         | 11 10                             | 9 8               | 7 6 5 4 3 2 1 0 |  |
| Name           | reserved |               | scichguard                        |                   |                 |  |
| Reset          | 0 0      | 0 0           | 0 0                               | 0 0               | 0 0 0 0 0 0 0 0 |  |
| Bits           | Access   | Name          | Description                       |                   |                 |  |
| [15:8]         | -        | reserved      | Reserved                          |                   |                 |  |
| [7:0]          | RW       | scichguard    | Character guard interval (in ETU) |                   |                 |  |

SCI BLKGUARD

SCI\_BLKGUARD is a block guard interval register. When the transfer directions of two consecutive characters are opposite, the interval between their start edges is the value defined in SCI\_BLKGUARD.



|        | Offset Address |             |    |    |                                                                                                   |    |   |   | Register Name |   |   |   |             |   |   |   | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|-------------|----|----|---------------------------------------------------------------------------------------------------|----|---|---|---------------|---|---|---|-------------|---|---|---|-------------------|--|--|--|--|--|--|--|
|        | 0x0058         |             |    |    |                                                                                                   |    |   |   | SCI_BLKGUARD  |   |   |   |             |   |   |   | 0x0000            |  |  |  |  |  |  |  |
| Bit    | 15             | 14          | 13 | 12 | 11                                                                                                | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3           | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |
| Name   | reserved       |             |    |    |                                                                                                   |    |   |   |               |   |   |   | sciblkguard |   |   |   |                   |  |  |  |  |  |  |  |
| Reset  | 0              | 0           | 0  | 0  | 0                                                                                                 | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0           | 0 | 0 | 0 |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name        |    |    | Description                                                                                       |    |   |   |               |   |   |   |             |   |   |   |                   |  |  |  |  |  |  |  |
| [15:8] | -              | reserved    |    |    | Reserved                                                                                          |    |   |   |               |   |   |   |             |   |   |   |                   |  |  |  |  |  |  |  |
| [7:0]  | RW             | sciblkguard |    |    | Minimum interval (unit: ETU) between two consecutive characters with opposite transfer directions |    |   |   |               |   |   |   |             |   |   |   |                   |  |  |  |  |  |  |  |

## SCI\_RXTIME

SCI\_RXTIME is an RX FIFO read timeout threshold register. When there are characters in the RX FIFO and the characters are not read within the period defined in SCI\_RXTIME, the RX read timeout interrupt is triggered and [SCI\\_RIS](#)[rtoutris] is set to 1.



### CAUTION

Never set SCI\_RXTIME[rxtime] to 0x0000 when you use the read timeout interrupt function of the RX FIFO.

|        | Offset Address |        |    |    |                                                 |    |   |   | Register Name |   |   |   |   |   |   |   | Total Reset Value |  |  |  |  |  |  |  |
|--------|----------------|--------|----|----|-------------------------------------------------|----|---|---|---------------|---|---|---|---|---|---|---|-------------------|--|--|--|--|--|--|--|
|        | 0x005C         |        |    |    |                                                 |    |   |   | SCI_RXTIME    |   |   |   |   |   |   |   | 0x0000            |  |  |  |  |  |  |  |
| Bit    | 15             | 14     | 13 | 12 | 11                                              | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                   |  |  |  |  |  |  |  |
| Name   | rxtime         |        |    |    |                                                 |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |
| Reset  | 0              | 0      | 0  | 0  | 0                                               | 0  | 0 | 0 | 0             | 0 | 0 | 0 | 0 | 0 | 0 | 0 |                   |  |  |  |  |  |  |  |
| Bits   | Access         | Name   |    |    | Description                                     |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |
| [15:0] | RW             | rxtime |    |    | RX read timeout threshold (unit: SCI_CLK cycle) |    |   |   |               |   |   |   |   |   |   |   |                   |  |  |  |  |  |  |  |

## SCI\_FIFOSTATUS

SCI\_FIFOSTATUS is a FIFO status register.



|        | Offset Address |          |    |                                                  |    |    |   |   | Register Name  |   |   |   |      |      |      |      | Total Reset Value |  |  |  |
|--------|----------------|----------|----|--------------------------------------------------|----|----|---|---|----------------|---|---|---|------|------|------|------|-------------------|--|--|--|
|        | 0x0060         |          |    |                                                  |    |    |   |   | SCI_FIFOSTATUS |   |   |   |      |      |      |      | 0x000A            |  |  |  |
| Bit    | 15             | 14       | 13 | 12                                               | 11 | 10 | 9 | 8 | 7              | 6 | 5 | 4 | 3    | 2    | 1    | 0    |                   |  |  |  |
| Name   | reserved       |          |    |                                                  |    |    |   |   |                |   |   |   | txfe | txff | txfe | txff |                   |  |  |  |
| Reset  | 0              | 0        | 0  | 0                                                | 0  | 0  | 0 | 0 | 0              | 0 | 0 | 0 | 1    | 0    | 1    | 0    |                   |  |  |  |
| Bits   | Access         | Name     |    | Description                                      |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |
| [15:4] | -              | reserved |    | Reserved                                         |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |
| [3]    | RO             | rxfe     |    | RX FIFO empty status<br>0: not empty<br>1: empty |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |
| [2]    | RO             | txff     |    | RX FIFO full status<br>0: not full<br>1: full    |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |
| [1]    | RO             | txfe     |    | TX FIFO empty status<br>0: not empty<br>1: empty |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |
| [0]    | RO             | txff     |    | TX FIFO full status<br>0: not full<br>1: full    |    |    |   |   |                |   |   |   |      |      |      |      |                   |  |  |  |

## SCI\_TXCOUNT

SCI\_TXCOUNT is a TX FIFO data count register.



### CAUTION

If an error defined in the T0 protocol occurs when characters are transmitted to the smart card, and the number of retransmission times exceeds the allowed value defined in SCI\_RETRY, an interrupt is triggered and [SCI\\_RIS\[txerrris\]](#) is set to 1. Before the next transmission, the TX FIFO must be cleared by writing to SCI\_TXCOUNT.



## **SCI\_RXCOUNT**

**SCI\_RXCOUNT** is an RX FIFO data count register.

SCI IMSC

SCI IMSC is an interrupt mask register.



|       |          | Offset Address<br>0x006C |          |          |                                                                         |          |       | Register Name<br>SCI_IMSC |          |           |            |            |         | Total Reset Value<br>0x0000 |          |           |          |  |
|-------|----------|--------------------------|----------|----------|-------------------------------------------------------------------------|----------|-------|---------------------------|----------|-----------|------------|------------|---------|-----------------------------|----------|-----------|----------|--|
| Bit   | Name     | 15                       | 14       | 13       | 12                                                                      | 11       | 10    | 9                         | 8        | 7         | 6          | 5          | 4       | 3                           | 2        | 1         | 0        |  |
|       | reserved |                          | txtideim | rxtideim | clkactim                                                                | clkstpim | rorim | rtoutim                   | chtoutim | blktoutim | atrdtoutim | atrstoutim | txerrim | carddnum                    | cardupim | cardoutim | cardinim |  |
| Reset |          | 0                        | 0        | 0        | 0                                                                       | 0        | 0     | 0                         | 0        | 0         | 0          | 0          | 0       | 0                           | 0        | 0         | 0        |  |
| Bits  | Access   | Name                     |          |          | Description                                                             |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [15]  | -        | reserved                 |          |          | Reserved                                                                |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [14]  | RW       | txtideim                 |          |          | TX FIFO overflow interrupt mask<br>0: masked<br>1: not masked           |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [13]  | RW       | rxtideim                 |          |          | RX FIFO overflow interrupt mask<br>0: masked<br>1: not masked           |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [12]  | RW       | clkactim                 |          |          | Smart card clock recovery interrupt mask<br>0: masked<br>1: not masked  |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [11]  | RW       | clkstpim                 |          |          | Smart card clock stop interrupt mask<br>0: masked<br>1: not masked      |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [10]  | RW       | rorim                    |          |          | RX overload interrupt mask<br>0: masked<br>1: not masked                |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [9]   | RW       | rtoutim                  |          |          | Read timeout interrupt mask<br>0: masked<br>1: not masked               |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [8]   | RW       | chtoutim                 |          |          | Character interval timeout interrupt mask<br>0: masked<br>1: not masked |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [7]   | RW       | blktoutim                |          |          | Block interval timeout interrupt mask<br>0: masked<br>1: not masked     |          |       |                           |          |           |            |            |         |                             |          |           |          |  |
| [6]   | RW       | atrdtoutim               |          |          | ATR RX timeout interrupt mask<br>0: masked<br>1: not masked             |          |       |                           |          |           |            |            |         |                             |          |           |          |  |



|     |    |            |                                                                  |
|-----|----|------------|------------------------------------------------------------------|
| [5] | RW | atrstoutim | ATR wait timeout interrupt mask<br>0: masked<br>1: not masked    |
| [4] | RW | txerrim    | TX error interrupt mask<br>0: masked<br>1: not masked            |
| [3] | RW | carddnim   | Smart card release interrupt mask<br>0: masked<br>1: not masked  |
| [2] | RW | cardupim   | Smart card activate interrupt mask<br>0: masked<br>1: not masked |
| [1] | RW | cardoutim  | Smart card remove interrupt mask<br>0: masked<br>1: not masked   |
| [0] | RW | ardinim    | Smart card insert interrupt mask<br>0: masked<br>1: not masked   |

## SCI\_RIS

SCI\_RIS is a raw interrupt register. This register defines the raw interrupts that are not masked.

|       |          | Offset Address |           | Register Name |             |        |          |           |            |             |             |         |           | Total Reset Value |            |          |
|-------|----------|----------------|-----------|---------------|-------------|--------|----------|-----------|------------|-------------|-------------|---------|-----------|-------------------|------------|----------|
|       |          | 0x0070         |           | SCI_RIS       |             |        |          |           |            |             |             |         |           | 0x400A            |            |          |
| Bit   | 15       | 14             | 13        | 12            | 11          | 10     | 9        | 8         | 7          | 6           | 5           | 4       | 3         | 2                 | 1          | 0        |
| Name  | reserved | txtideris      | rxtideris | clkactris     | clkspiris   | rroris | ritouris | chtoutris | blktoutris | atrdtoutris | atrstoutris | txerris | carddnris | cardupris         | cardoutris | ardinris |
| Reset | 0        | 1              | 0         | 0             | 0           | 0      | 0        | 0         | 0          | 0           | 0           | 0       | 1         | 0                 | 1          | 0        |
| Bits  | Access   | Name           |           |               | Description |        |          |           |            |             |             |         |           |                   |            |          |
| [15]  | -        | reserved       |           |               | Reserved    |        |          |           |            |             |             |         |           |                   |            |          |



|      |    |             |                                                                                                                                                                                                                                   |
|------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [14] | RO | txtideris   | Raw TX FIFO overflow interrupt. This bit is set to 1 if the number of characters in the TX FIFO is less than or equal to the threshold.<br>0: No interrupt is generated.<br>1: An interrupt is generated.                         |
| [13] | RO | rxtideris   | Raw RX FIFO overflow interrupt. This bit is set to 1 if the number of characters in the RX FIFO is greater than or equal to the threshold.<br>0: No interrupt is generated.<br>1: An interrupt is generated.                      |
| [12] | RO | clkactris   | Raw smart card clock recovery interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                         |
| [11] | RO | clkstpris   | Raw smart card clock stop interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                             |
| [10] | RO | rrorris     | Raw RX overload interrupt. This bit is set to 1 if the RX FIFO is full and new characters are received.<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                         |
| [9]  | RO | rtoutris    | Raw read timeout interrupt. This bit is set to 1 if the CPU does not fetch data in the RX FIFO within the specified period.<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                     |
| [8]  | RO | chtoutris   | Raw character interval timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                        |
| [7]  | RO | blktooutris | Raw block interval timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                            |
| [6]  | RO | atrdtoutris | Raw ATR RX timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                                    |
| [5]  | RO | atrstoutris | Raw ATR wait timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                                                                                                                                  |
| [4]  | RO | txerrris    | Raw TX error interrupt. This bit is set to 1 if an error occurs in the transmitted characters and the error still persists after a specified number of retries.<br>0: No interrupt is generated.<br>1: An interrupt is generated. |



|     |    |            |                                                                                                     |
|-----|----|------------|-----------------------------------------------------------------------------------------------------|
| [3] | RO | carddnris  | Raw smart card release interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.  |
| [2] | RO | cardupris  | Raw smart card activate interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [1] | RO | cardoutris | Raw smart card remove interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.   |
| [0] | RO | ardinris   | Raw smart card insert interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.   |

## SCI\_MIS

SCI\_MIS is a masked interrupt register. This register defines the results obtained after raw interrupts are masked.

|       | Offset Address<br>0x0074 |           |           |                                                                                                              |           |        |          |           | Register Name<br>SCI_MIS |            |            |         |           |           |            |          | Total Reset Value<br>0x0000 |  |  |  |  |  |  |  |
|-------|--------------------------|-----------|-----------|--------------------------------------------------------------------------------------------------------------|-----------|--------|----------|-----------|--------------------------|------------|------------|---------|-----------|-----------|------------|----------|-----------------------------|--|--|--|--|--|--|--|
| Bit   | 15                       | 14        | 13        | 12                                                                                                           | 11        | 10     | 9        | 8         | 7                        | 6          | 5          | 4       | 3         | 2         | 1          | 0        |                             |  |  |  |  |  |  |  |
| Name  | reserved                 | txtidemis | rxtidemis | clkactmis                                                                                                    | clkstpmis | rormis | rtoutmis | chtoutmis | blkoutmis                | atrdoutmis | atrstoutim | txermis | carddnmis | cardupmis | cardoutmis | cardnmis |                             |  |  |  |  |  |  |  |
| Reset | 0                        | 0         | 0         | 0                                                                                                            | 0         | 0      | 0        | 0         | 0                        | 0          | 0          | 0       | 0         | 0         | 0          | 0        |                             |  |  |  |  |  |  |  |
| Bits  | Access                   | Name      |           | Description                                                                                                  |           |        |          |           |                          |            |            |         |           |           |            |          |                             |  |  |  |  |  |  |  |
| [15]  | -                        | reserved  |           | Reserved                                                                                                     |           |        |          |           |                          |            |            |         |           |           |            |          |                             |  |  |  |  |  |  |  |
| [14]  | RO                       | txtidemis |           | Masked TX FIFO overflow interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |           |        |          |           |                          |            |            |         |           |           |            |          |                             |  |  |  |  |  |  |  |
| [13]  | RO                       | rxtidemis |           | Masked RX FIFO overflow interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |           |        |          |           |                          |            |            |         |           |           |            |          |                             |  |  |  |  |  |  |  |
| [12]  | RO                       | clkactmis |           | Masked smart card clock recovery interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated. |           |        |          |           |                          |            |            |         |           |           |            |          |                             |  |  |  |  |  |  |  |



|      |    |             |                                                                                                               |
|------|----|-------------|---------------------------------------------------------------------------------------------------------------|
| [11] | RO | clkstpmis   | Masked smart card clock stop interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.      |
| [10] | RO | rormis      | Masked RX overload interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                |
| [9]  | RO | rtoutmis    | Masked read timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.               |
| [8]  | RO | chtoutmis   | Masked character interval timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated. |
| [7]  | RO | blktoutmis  | Masked block interval timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.     |
| [6]  | RO | atrdtoutmis | Masked ATR RX timeout interrupt status<br>0: No interrupt is generated.<br>1: An interrupt is generated.      |
| [5]  | RO | atrstoutim  | Masked ATR wait timeout interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.           |
| [4]  | RO | txerrmis    | Masked TX error interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.                   |
| [3]  | RO | carddnmis   | Masked smart card release interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.         |
| [2]  | RO | cardupmis   | Masked smart card activate interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.        |
| [1]  | RO | cardoutmis  | Masked smart card remove interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |
| [0]  | RO | ardinmis    | Masked smart card insert interrupt<br>0: No interrupt is generated.<br>1: An interrupt is generated.          |



## SCI\_ICR

SCI\_ICR is an interrupt clear register.

|         | Offset Address |            |          |                                                                            | Register Name |         |          |           |           |            |         |         | Total Reset Value |           |          |   |
|---------|----------------|------------|----------|----------------------------------------------------------------------------|---------------|---------|----------|-----------|-----------|------------|---------|---------|-------------------|-----------|----------|---|
|         | 0x0078         |            |          |                                                                            | SCI_ICR       |         |          |           |           |            |         |         | 0x0000            |           |          |   |
| Bit     | 15             | 14         | 13       | 12                                                                         | 11            | 10      | 9        | 8         | 7         | 6          | 5       | 4       | 3                 | 2         | 1        | 0 |
| Name    | reserved       |            | clkactic | clkstpic                                                                   | roric         | rtoutic | chtoutic | blktoutic | atrdtouic | atrstoutic | txerric | cardnic | cardupic          | cardoutic | cardinic |   |
| Reset   | 0              | 0          | 0        | 0                                                                          | 0             | 0       | 0        | 0         | 0         | 0          | 0       | 0       | 0                 | 0         | 0        | 0 |
| Bits    | Access         | Name       |          | Description                                                                |               |         |          |           |           |            |         |         |                   |           |          |   |
| [15:13] | -              | reserved   |          | Reserved                                                                   |               |         |          |           |           |            |         |         |                   |           |          |   |
| [12]    | WO             | clkactic   |          | Smart card clock recovery interrupt clear<br>0: not cleared<br>1: cleared  |               |         |          |           |           |            |         |         |                   |           |          |   |
| [11]    | WO             | clkstpic   |          | Smart card clock stop interrupt clear<br>0: not cleared<br>1: cleared      |               |         |          |           |           |            |         |         |                   |           |          |   |
| [10]    | WO             | roric      |          | RX overload interrupt clear<br>0: not cleared<br>1: cleared                |               |         |          |           |           |            |         |         |                   |           |          |   |
| [9]     | WO             | rtoutic    |          | Read timeout interrupt clear<br>0: not cleared<br>1: cleared               |               |         |          |           |           |            |         |         |                   |           |          |   |
| [8]     | WO             | chtoutic   |          | Character interval timeout interrupt clear<br>0: not cleared<br>1: cleared |               |         |          |           |           |            |         |         |                   |           |          |   |
| [7]     | WO             | blktoutic  |          | Block interval timeout interrupt clear<br>0: not cleared<br>1: cleared     |               |         |          |           |           |            |         |         |                   |           |          |   |
| [6]     | WO             | atrdtouic  |          | ATR RX timeout interrupt clear<br>0: not cleared<br>1: cleared             |               |         |          |           |           |            |         |         |                   |           |          |   |
| [5]     | WO             | atrstoutic |          | ATR wait timeout interrupt clear<br>0: not cleared<br>1: cleared           |               |         |          |           |           |            |         |         |                   |           |          |   |



|     |    |           |                                                                     |
|-----|----|-----------|---------------------------------------------------------------------|
| [4] | WO | txerric   | TX error interrupt clear<br>0: not cleared<br>1: cleared            |
| [3] | WO | carddnic  | Smart card release interrupt clear<br>0: not cleared<br>1: cleared  |
| [2] | WO | cardupic  | Smart card activate interrupt clear<br>0: not cleared<br>1: cleared |
| [1] | WO | cardoutic | Smart card remove interrupt clear<br>0: not cleared<br>1: cleared   |
| [0] | WO | cardinic  | Smart card insert interrupt clear<br>0: not cleared<br>1: cleared   |

## SCI\_SYNCACT

SCI\_SYNCACT is an activation register in sync mode. The register is used to enable data and clocks, implement reset, and control power supply in sync mode. The register also provides status information. The corresponding status bits are automatically updated during activation, release, or warm reset.

| Offset Address<br>0x007C |          |             |    |    |                                                                                      |    |             |            |               | Register Name<br>SCI_SYNCACT |            |              |     |        |       |       |       |
|--------------------------|----------|-------------|----|----|--------------------------------------------------------------------------------------|----|-------------|------------|---------------|------------------------------|------------|--------------|-----|--------|-------|-------|-------|
| Bit                      | 15       | 14          | 13 | 12 | 11                                                                                   | 10 | 9           | 8          | 7             | 6                            | 5          | 4            | 3   | 2      | 1     | 0     |       |
| Name                     | reserved |             |    |    |                                                                                      |    | cardpresent | nscidataen | nscidataouten | scilckout                    | nsciclkken | rsciclkouten | fcb | dataen | clken | reset | power |
| Reset                    | 0        | 0           | 0  | 0  | 0                                                                                    | 0  | 0           | 0          | 0             | 0                            | 0          | 0            | 0   | 0      | 0     | 0     | 0     |
| Bits                     | Access   | Name        |    |    | Description                                                                          |    |             |            |               |                              |            |              |     |        |       |       |       |
| [15:11]                  | -        | reserved    |    |    | Reserved                                                                             |    |             |            |               |                              |            |              |     |        |       |       |       |
| [10]                     | RO       | cardpresent |    |    | Smart card presence<br>0: No smart card is detected.<br>1: A smart card is detected. |    |             |            |               |                              |            |              |     |        |       |       |       |



|     |    |               |                                                                                                       |
|-----|----|---------------|-------------------------------------------------------------------------------------------------------|
| [9] | RO | nscidataen    | Tristate control enable for the off-chip buffer of data<br>0: enabled<br>1: disabled                  |
| [8] | RO | nscidataouten | Tristate control enable for the data buffer<br>0: enabled<br>1: disabled                              |
| [7] | RO | sciclkout     | SCI clock output enable<br>0: enabled<br>1: disabled                                                  |
| [6] | RO | nsciclknen    | Tristate control enable for the off-chip buffer of the clock<br>0: enabled<br>1: disabled             |
| [5] | RO | nsciclkouten  | Tristate control enable for the data buffer<br>0: enabled<br>1: disabled                              |
| [4] | RW | fcb           | Functional code. This bit works with the creset bit to indicate the type of a command to be executed. |
| [3] | RW | dataen        | SCI data output enable<br>0: disabled<br>1: enabled                                                   |
| [2] | RW | clken         | SCI clock output enable<br>0: disabled<br>1: enabled                                                  |
| [1] | RW | creset        | Smart card reset signal control enable<br>0: enabled<br>1: disabled                                   |
| [0] | RW | power         | Card power (VCC) enable<br>0: Enabled.<br>1: disabled                                                 |

## SCI\_SYNCTX

SCI\_SYNCTX is a TX clock and data stream register in sync mode. It is used to determine whether to transmit clocks and data in sync mode.



| Offset Address<br>0x0080 |          |          |    |                                                                                                                 |    |    |   |   |   | Register Name<br>SCI_SYNCTX |      |      |        | Total Reset Value<br>0x0000 |      |       |  |
|--------------------------|----------|----------|----|-----------------------------------------------------------------------------------------------------------------|----|----|---|---|---|-----------------------------|------|------|--------|-----------------------------|------|-------|--|
| Bit                      | 15       | 14       | 13 | 12                                                                                                              | 11 | 10 | 9 | 8 | 7 | 6                           | 5    | 4    | 3      | 2                           | 1    | 0     |  |
| Name                     | reserved |          |    |                                                                                                                 |    |    |   |   |   |                             | wfcb | wrst | wclken | wdataen                     | wclk | wdata |  |
| Reset                    | 0        | 0        | 0  | 0                                                                                                               | 0  | 0  | 0 | 0 | 0 | 0                           | 0    | 0    | 0      | 0                           | 0    | 0     |  |
| Bits                     | Access   | Name     |    | Description                                                                                                     |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [15:6]                   | -        | reserved |    | Reserved                                                                                                        |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [5]                      | RW       | wfcb     |    | Functional code in sync mode. The bit works with the wrst bit to indicate the type of a command to be executed. |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [4]                      | RW       | wrst     |    | Card reset signal enable in sync mode<br>0: disabled<br>1: enabled                                              |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [3]                      | RW       | wclken   |    | Tristate control enable for the off-chip buffer of the clock in sync mode<br>0: enabled<br>1: disabled          |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [2]                      | RW       | wdataen  |    | Card data output enable in sync mode<br>0: disabled<br>1: enabled                                               |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [1]                      | RW       | wclk     |    | SCI clock enable in sync mode<br>0: enabled<br>1: disabled                                                      |    |    |   |   |   |                             |      |      |        |                             |      |       |  |
| [0]                      | RW       | wdata    |    | SCI data enable in sync mode<br>0: enabled<br>1: disabled                                                       |    |    |   |   |   |                             |      |      |        |                             |      |       |  |

## SCI\_SYNCRX

SCI\_SYNCRX is an RX clock and data stream register in sync mode. It is used to determine whether to receive clocks and data in sync mode.



| Offset Address |          |          |   |             |   |            |   |   |   | Register Name |        |   |   |   | Total Reset Value |       |   |   |   |  |
|----------------|----------|----------|---|-------------|---|------------|---|---|---|---------------|--------|---|---|---|-------------------|-------|---|---|---|--|
| Bit            | 0x0084   |          |   |             |   | SCI_SYNCRX |   |   |   |               | 0x0000 |   |   |   |                   |       |   |   |   |  |
| Name           | reserved |          |   |             |   |            |   |   |   |               |        |   |   |   | rclk              | rdata |   |   |   |  |
| Reset          | 0        | 0        | 0 | 0           | 0 | 0          | 0 | 0 | 0 | 0             | 0      | 0 | 0 | 0 | 0                 | 0     | 0 | 0 | 0 |  |
| Bits           | Access   | Name     |   | Description |   |            |   |   |   |               |        |   |   |   |                   |       |   |   |   |  |
| [15:2]         | -        | reserved |   | Reserved    |   |            |   |   |   |               |        |   |   |   |                   |       |   |   |   |  |
| [1]            | RO       | rclk     |   | Raw clock   |   |            |   |   |   |               |        |   |   |   |                   |       |   |   |   |  |
| [0]            | RO       | rdata    |   | Raw data    |   |            |   |   |   |               |        |   |   |   |                   |       |   |   |   |  |



## Contents

---

|                                   |     |
|-----------------------------------|-----|
| A Acronyms and Abbreviations..... | A-1 |
|-----------------------------------|-----|



# A Acronyms and Abbreviations

## A

|             |                                           |
|-------------|-------------------------------------------|
| <b>AAC</b>  | advanced audio coding                     |
| <b>AAF</b>  | anti-aliasing filter                      |
| <b>ABR</b>  | average bit rate                          |
| <b>AC</b>   | alternating current                       |
| <b>ACA</b>  | accessory charge adapter                  |
| <b>ACC</b>  | automatic contrast control                |
| <b>ACD</b>  | auto command done                         |
| <b>ACM</b>  | adaptive coding and modulation            |
| <b>ADP</b>  | attach detection protocol                 |
| <b>ADC</b>  | analog-to-digital converter               |
| <b>AE</b>   | automatic exposure                        |
| <b>AEC</b>  | audio echo cancellation                   |
| <b>AES</b>  | advanced encryption standard              |
| <b>AF</b>   | adaption field                            |
| <b>AGC</b>  | automatic gain control                    |
| <b>AHB</b>  | advanced high-performance bus             |
| <b>AI</b>   | audio input                               |
| <b>AIU</b>  | audio input unit                          |
| <b>ALU</b>  | arithmetic logic unit                     |
| <b>AMBA</b> | advanced microcontroller bus architecture |
| <b>AMP</b>  | asymmetric multi-processing               |
| <b>ANI</b>  | automatic number identification           |
| <b>ANR</b>  | automatic noise reduction                 |



|              |                                                 |
|--------------|-------------------------------------------------|
| <b>AO</b>    | audio output                                    |
| <b>AOU</b>   | audio output unit                               |
| <b>AP</b>    | access point                                    |
| <b>APB</b>   | advanced peripheral bus                         |
| <b>API</b>   | application programming interface               |
| <b>APLL</b>  | analog phase-locked loop                        |
| <b>APSK</b>  | amplitude phase shift keying                    |
| <b>AQTD</b>  | alternate queue transfer descriptor             |
| <b>ARM</b>   | advanced RISC machines                          |
| <b>ARGB</b>  | alpha, red, green, blue                         |
| <b>ASF</b>   | advanced specification format                   |
| <b>ATA</b>   | advanced technology attachment                  |
| <b>ATAH</b>  | ATA host controller                             |
| <b>ATAPI</b> | advanced technology attachment packet interface |
| <b>ATR</b>   | answer to reset                                 |
| <b>ATTR</b>  | attribute                                       |
| <b>AUD</b>   | audio                                           |
| <b>AV</b>    | audio & video                                   |
| <b>AVI</b>   | auxiliary video information                     |
| <b>AVS</b>   | audio video coding standard                     |
| <b>AWB</b>   | automatic white balance                         |
| <b>AXI</b>   | advanced eXtensible interface                   |

## B

|             |                            |
|-------------|----------------------------|
| <b>BB</b>   | baseband                   |
| <b>BCH</b>  | Bose-Chaudhuri-Hocquenghem |
| <b>BCM</b>  | byte counter modified      |
| <b>BEP</b>  | boot entrance point        |
| <b>BER</b>  | bit error rate             |
| <b>BGA</b>  | ball grid array            |
| <b>BIST</b> | built-in self test         |
| <b>BIU</b>  | bus interface unit         |
| <b>BMC</b>  | bi-phase mark coding       |



|              |                             |
|--------------|-----------------------------|
| <b>BND</b>   | bayonet nut connector       |
| <b>BOM</b>   | bill of material            |
| <b>BPD</b>   | bit plan decoder            |
| <b>BPSK</b>  | binary phase shift keying   |
| <b>BRG</b>   | bridge                      |
| <b>BSP</b>   | board support package       |
| <b>BVACT</b> | bottom vertical active area |
| <b>BVBB</b>  | bottom vertical back blank  |
| <b>BVFB</b>  | bottom vertical front blank |

**C**

|              |                                                 |
|--------------|-------------------------------------------------|
| <b>CA</b>    | conditional access                              |
| <b>CABAC</b> | context-based adaptive binary arithmetic coding |
| <b>CAR</b>   | committed access rate                           |
| <b>CAS</b>   | column address signal.                          |
| <b>CAVLC</b> | context adaptive variable length coding         |
| <b>CBC</b>   | cipher block chaining                           |
| <b>CBR</b>   | constant bit rate                               |
| <b>CCB</b>   | change control board                            |
| <b>CCC</b>   | command completion coalescing                   |
| <b>CCD</b>   | charge-coupled device                           |
| <b>CCM</b>   | constant coding and modulation                  |
| <b>CD</b>    | command done or collision detection             |
| <b>CDR</b>   | clock data recovery                             |
| <b>CEC</b>   | consumer electronics control                    |
| <b>CF</b>    | compact flash                                   |
| <b>CFB</b>   | cipher feedback                                 |
| <b>CFR</b>   | crest factor reduction                          |
| <b>CGI</b>   | common gate interface                           |
| <b>CGMS</b>  | copy generation management system               |
| <b>CI</b>    | common interface                                |
| <b>CIC</b>   | cascaded integrator comb                        |
| <b>CIU</b>   | card interface unit                             |



|               |                                         |
|---------------|-----------------------------------------|
| <b>CL</b>     | CAS latency                             |
| <b>CLK</b>    | clock                                   |
| <b>CML</b>    | current mode logic                      |
| <b>CMOS</b>   | complementary metal-oxide semiconductor |
| <b>CN</b>     | carrier noise                           |
| <b>CNG</b>    | comfort noise generator                 |
| <b>CODEC</b>  | coder/decoder                           |
| <b>CP</b>     | charge pump                             |
| <b>CPL</b>    | completion                              |
| <b>CPLD</b>   | complex programmable logic device       |
| <b>CPU</b>    | central processing unit                 |
| <b>CR</b>     | carrier recovery                        |
| <b>CRAMFS</b> | compressed ROM file system              |
| <b>CRC</b>    | cyclic redundancy check                 |
| <b>CRG</b>    | clock and reset generator               |
| <b>CRS</b>    | completion retry request                |
| <b>CS</b>     | chip select                             |
| <b>CSA</b>    | common scramble algorithm               |
| <b>CSI</b>    | camera serial interface                 |
| <b>CSIX</b>   | common switch interface                 |
| <b>CSMD</b>   | carrier sense multiple access           |
| <b>CTI</b>    | chroma transient improvement            |
| <b>CTR</b>    | counter                                 |
| <b>CTS</b>    | clear to send                           |
| <b>CVBS</b>   | composite video broadcast signal        |
| <b>CW</b>     | cipher word                             |

**D**

|             |                                |
|-------------|--------------------------------|
| <b>DAC</b>  | digital-to-analog converter    |
| <b>DAG</b>  | digital automatic gain         |
| <b>DAGC</b> | digital automatic gain control |
| <b>DAV</b>  | DMA of audio and video         |
| <b>DC</b>   | direct current                 |



|               |                                      |
|---------------|--------------------------------------|
| <b>DCD</b>    | data connect detection               |
| <b>DCRC</b>   | data CRC error                       |
| <b>DDC</b>    | display data channel                 |
| <b>DDR</b>    | double data-rate                     |
| <b>DDRC</b>   | double data rate controller          |
| <b>DHCP</b>   | dynamic host configuration protocol  |
| <b>DEM</b>    | dynamic-element matching             |
| <b>DES</b>    | data encryption standard             |
| <b>DFT</b>    | design for testability               |
| <b>DIP</b>    | dual in-line package                 |
| <b>DIS</b>    | digital image stabilization          |
| <b>DiSEqC</b> | digital satellite equipment control  |
| <b>DLL</b>    | delay locked loop                    |
| <b>DM</b>     | data mask                            |
| <b>DMA</b>    | direct memory access                 |
| <b>DMAC</b>   | direct memory access controller      |
| <b>DNR</b>    | digital noise reduction              |
| <b>DP</b>     | data path                            |
| <b>DPLL</b>   | digital phase-locked loop            |
| <b>DQ</b>     | data input/output                    |
| <b>DQS</b>    | data strobe                          |
| <b>DR</b>     | design requirement                   |
| <b>DRAM</b>   | dynamic random access memory         |
| <b>DRC</b>    | dynamic range compression            |
| <b>DRM</b>    | digital rights management            |
| <b>DRTO</b>   | data read timeout                    |
| <b>DSI</b>    | display serial interface             |
| <b>DSU</b>    | dedicated scaling unit               |
| <b>DTMF</b>   | dual tone multi frequency            |
| <b>DTO</b>    | data transfer over                   |
| <b>DVB</b>    | digital video broadcasting           |
| <b>DVB-S</b>  | digital video broadcasting-satellite |
| <b>DVD</b>    | digital versatile disc               |



|               |                                                     |
|---------------|-----------------------------------------------------|
| <b>DVI</b>    | digital visual interface                            |
| <b>DVR</b>    | digital video recorder                              |
| <b>DWA</b>    | data weighted averaging                             |
| <b>E</b>      |                                                     |
| <b>E2PROM</b> | electrically erasable programmable read-only memory |
| <b>EAV</b>    | end of active video                                 |
| <b>EB</b>     | eviction buffer                                     |
| <b>EBE</b>    | end-bit error                                       |
| <b>EBI</b>    | external bus interface                              |
| <b>ECB</b>    | electronic codebook                                 |
| <b>ECC</b>    | error correcting code                               |
| <b>ECM</b>    | entitlement control message                         |
| <b>ECS</b>    | embedded CPU subsystem                              |
| <b>ED</b>     | exposed die                                         |
| <b>EDID</b>   | extended display identification data                |
| <b>EEE</b>    | energy efficient Ethernet                           |
| <b>EHCI</b>   | enhanced host controller interface                  |
| <b>EMI</b>    | electromagnetic interference                        |
| <b>EMM</b>    | entitlement management message                      |
| <b>eMMC</b>   | embedded multimedia card                            |
| <b>EOP</b>    | end of PES                                          |
| <b>EoS</b>    | Ethernet over SONET/SDH                             |
| <b>EP</b>     | end point                                           |
| <b>EPG</b>    | electronic program guide                            |
| <b>EQU</b>    | equalizer                                           |
| <b>ERR</b>    | error                                               |
| <b>ES</b>     | element stream                                      |
| <b>eSATA</b>  | external serial advanced technology attachment      |
| <b>ESD</b>    | electrostatic discharge                             |
| <b>ESR</b>    | equivalent series resistance                        |
| <b>ETH</b>    | Ethernet                                            |
| <b>ETU</b>    | elementary time unit                                |



**F**

|              |                              |
|--------------|------------------------------|
| <b>FAS</b>   | frame aligning signal        |
| <b>FBE</b>   | feedback equalizer           |
| <b>FC</b>    | switch fabric                |
| <b>FCBGA</b> | flip-chip ball grid array    |
| <b>FCCSP</b> | flip-chip chip scale package |
| <b>FEC</b>   | forward error correction     |
| <b>FER</b>   | frame error rate             |
| <b>FFC</b>   | flexible flat cable          |
| <b>FFE</b>   | feed forward equalizer       |
| <b>FIFO</b>  | first in first out           |
| <b>FIQ</b>   | fast interrupt request       |
| <b>FIR</b>   | finite impulse response      |
| <b>FIS</b>   | frame information structure  |
| <b>FOD</b>   | field order detect           |
| <b>FPC</b>   | flexible printed connector   |
| <b>FPU</b>   | floating-point unit          |
| <b>FRUN</b>  | FIFO underrun/overrun error  |
| <b>FSK</b>   | frequency shift keying       |
| <b>FTP</b>   | File Transfer Protocol       |

**G**

|              |                                        |
|--------------|----------------------------------------|
| <b>GFP-F</b> | frame-mapped generic framing procedure |
| <b>GFP-T</b> | transparent generic framing procedure  |
| <b>GHB</b>   | global history buffer                  |
| <b>GIC</b>   | generic interrupt controller           |
| <b>GOP</b>   | group of picture                       |
| <b>GS</b>    | generic stream                         |
| <b>GMAC</b>  | gigabit media access control           |
| <b>GND</b>   | ground                                 |
| <b>GPIO</b>  | general purpose input/output           |
| <b>GPL</b>   | GNU general public license             |



**GPU** graphics processing unit

**H**

|              |                                           |
|--------------|-------------------------------------------|
| <b>HBA</b>   | host bus adapter                          |
| <b>HBP</b>   | horizontal back porch                     |
| <b>HD</b>    | high definition                           |
| <b>HDCP</b>  | high-bandwidth digital content protection |
| <b>HDI</b>   | high density interconnector               |
| <b>HDMI</b>  | high definition multimedia interface      |
| <b>HFP</b>   | horizontal front porch                    |
| <b>HIAO</b>  | high-performance audio output interface   |
| <b>HPW</b>   | horizontal pulse width                    |
| <b>HSTL</b>  | high speed transceiver logic              |
| <b>HTML</b>  | hypertext markup language                 |
| <b>HACT</b>  | horizontal active area                    |
| <b>HFB</b>   | horizontal front blank                    |
| <b>HL</b>    | high level                                |
| <b>HLDC</b>  | horizontal lens distortion correction     |
| <b>HLE</b>   | hardware locked error                     |
| <b>HNP</b>   | host negotiation protocol                 |
| <b>HTO</b>   | data starvation-by-host timeout           |
| <b>HP</b>    | high profile                              |
| <b>HSIC</b>  | high-speed inter-chip                     |
| <b>HSS</b>   | high-speed serializer/deserializer        |
| <b>HTTP</b>  | Hypertext Transfer Protocol               |
| <b>HTTPS</b> | Hypertext Transfer Protocol Secure        |
| <b>HVBB</b>  | horizontal back blank                     |

**I**

|                       |                                               |
|-----------------------|-----------------------------------------------|
| <b>I</b>              | in-phase                                      |
| <b>IBIS</b>           | input/output buffer information specification |
| <b>IC</b>             | integrated circuit                            |
| <b>I<sup>2</sup>C</b> | inter-integrated circuit                      |



|                       |                                       |
|-----------------------|---------------------------------------|
| <b>I<sup>2</sup>S</b> | inter-IC sound                        |
| <b>I/O</b>            | input/output                          |
| <b>IOC</b>            | I/O configuration                     |
| <b>IP</b>             | Internet Protocol                     |
| <b>ISI</b>            | input stream identifier               |
| <b>ISP</b>            | image signal processor                |
| <b>IDE</b>            | integrated device electronic          |
| <b>LDPC</b>           | low density parity check code         |
| <b>IDR</b>            | intermediate data rate                |
| <b>IF</b>             | intermediate frequency                |
| <b>IGMP</b>           | Internet Group Management Protocol    |
| <b>LMS</b>            | linear mean square                    |
| <b>IPF</b>            | IP filter                             |
| <b>IPv4</b>           | Internet Protocol Version 4           |
| <b>IR</b>             | infrared                              |
| <b>IRQ</b>            | interrupt request                     |
| <b>ISI</b>            | input stream identifier               |
| <b>ISP</b>            | image signal processor                |
| <b>ISR</b>            | interrupt service routine             |
| <b>ITCM</b>           | instruction tightly coupled memory    |
| <b>ITLA</b>           | integrated tunable laser assembly     |
| <b>ITU</b>            | International Telecommunication Union |
| <b>IV</b>             | initialization vector                 |

**J**

|              |                                        |
|--------------|----------------------------------------|
| <b>JFFS2</b> | journaling flash file system version 2 |
| <b>JPEG</b>  | Joint Photographic Experts Group       |
| <b>JPGE</b>  | JPEG encoder                           |
| <b>JTAG</b>  | Joint Test Action Group                |

**K**

|           |            |
|-----------|------------|
| <b>KL</b> | key ladder |
|-----------|------------|



**L**

|               |                                            |
|---------------|--------------------------------------------|
| <b>LCD</b>    | liquid crystal display                     |
| <b>LDO</b>    | low dropout regulator                      |
| <b>LDPC</b>   | low-density parity check code              |
| <b>LED</b>    | light emitting diode                       |
| <b>LFB</b>    | line fill buffer                           |
| <b>LFSR</b>   | linear feedback shifting register          |
| <b>LMR</b>    | load mode register                         |
| <b>LMS</b>    | least mean square                          |
| <b>LNB</b>    | low noise block                            |
| <b>LOS</b>    | loss of signal                             |
| <b>LPI</b>    | low-power idle                             |
| <b>LRB</b>    | line read buffer                           |
| <b>LSB</b>    | least significant bit                      |
| <b>LSP</b>    | label switched path                        |
| <b>LSN</b>    | logic sector number                        |
| <b>LTI</b>    | luma transient improvement                 |
| <b>LVDS</b>   | low-voltage differential signaling         |
| <b>LVPECL</b> | low-voltage positive emitter coupled logic |
| <b>LVTTL</b>  | low-voltage transistor-transistor logic    |
| <b>LVPECL</b> | low-voltage positive emitter-coupled logic |

**M**

|              |                                 |
|--------------|---------------------------------|
| <b>MAC</b>   | media access control            |
| <b>MBAFF</b> | macroblock adaptive frame field |
| <b>MCE</b>   | media control engine            |
| <b>MCU</b>   | microprogrammed control unit    |
| <b>MD</b>    | motion detection                |
| <b>MDDRC</b> | multiport DDRC                  |
| <b>MDIO</b>  | management data input/output    |
| <b>MDU</b>   | motion detect unit              |
| <b>MF</b>    | matched filter                  |
| <b>MQFN</b>  | mapped quad flat non-leaded     |



|             |                                                    |
|-------------|----------------------------------------------------|
| <b>MHL</b>  | mobile high-definition link                        |
| <b>MII</b>  | media independent interface                        |
| <b>MIPI</b> | mobile industry processor interface                |
| <b>MIPS</b> | microprocessor without interlocked pipeline stages |
| <b>MLC</b>  | multi-level cell                                   |
| <b>MLF</b>  | malformed                                          |
| <b>MMB</b>  | media memory block                                 |
| <b>MMC</b>  | multimedia card                                    |
| <b>MMU</b>  | memory management unit                             |
| <b>MMZ</b>  | media memory zone                                  |
| <b>MP</b>   | main profile                                       |
| <b>MPI</b>  | MPP programming interface                          |
| <b>MPE</b>  | media processing engine                            |
| <b>MPLL</b> | multiplying phase-locked loop                      |
| <b>MPP</b>  | media processing platform                          |
| <b>MRL</b>  | manually-operated retention latch                  |
| <b>MSB</b>  | most significant bit                               |
| <b>MSE</b>  | mean square error                                  |
| <b>MSG</b>  | message                                            |
| <b>MV</b>   | motion vector                                      |

## N

|              |                                       |
|--------------|---------------------------------------|
| <b>NAL</b>   | network abstraction layer             |
| <b>NANDC</b> | NAND flash controller                 |
| <b>NC</b>    | not connect                           |
| <b>NCQ</b>   | native command queuing                |
| <b>NLP</b>   | non-linear processor                  |
| <b>NR</b>    | noise reduction                       |
| <b>NRZ</b>   | non-return-to-zero                    |
| <b>NTSC</b>  | National Television Systems Committee |
| <b>NVR</b>   | network video recorder                |

## O



|             |                                |
|-------------|--------------------------------|
| <b>OCT</b>  | on-chip termination            |
| <b>OD</b>   | open drain                     |
| <b>ODT</b>  | on-die termination             |
| <b>OEN</b>  | output enable                  |
| <b>OFB</b>  | output feedback                |
| <b>OHCI</b> | open host controller interface |
| <b>OOB</b>  | out of band                    |
| <b>OP</b>   | operational amplifier          |
| <b>OR</b>   | original requirement           |
| <b>OSC</b>  | oscillator                     |
| <b>OSD</b>  | on screen display              |
| <b>OTG</b>  | on-the-go                      |
| <b>OTP</b>  | one time programmable          |
| <b>OTU</b>  | optical transponder unit       |

**P**

|               |                                           |
|---------------|-------------------------------------------|
| <b>PAD</b>    | packet assembler/disassembler             |
| <b>PAFF</b>   | picture adaptive frame field              |
| <b>PAL</b>    | phase alternating line                    |
| <b>PCB</b>    | printed circuit board                     |
| <b>PCI</b>    | peripheral component interconnect         |
| <b>PCIe</b>   | peripheral component interconnect express |
| <b>PCIV</b>   | PCI view                                  |
| <b>PCR</b>    | program clock reference                   |
| <b>PCM</b>    | pulse code modulation                     |
| <b>PDM</b>    | pulse density modulation                  |
| <b>PECL</b>   | positive emitter coupled logic            |
| <b>PER</b>    | packet error rate                         |
| <b>PES</b>    | packetized elementary stream              |
| <b>PG</b>     | power/ground                              |
| <b>PHY</b>    | physical                                  |
| <b>PID</b>    | packet ID                                 |
| <b>PIM-DM</b> | protocol independent multicast dense mode |



|               |                                            |
|---------------|--------------------------------------------|
| <b>PIM-SM</b> | protocol independent multicast sparse mode |
| <b>PIO</b>    | programmable input/output                  |
| <b>SSA</b>    | secure software authentication             |
| <b>PLL</b>    | phase-locked loop                          |
| <b>PLS</b>    | physical layer signaling                   |
| <b>PM</b>     | port multiplexer                           |
| <b>PMoC</b>   | power management of chip                   |
| <b>PMP</b>    | personal media player                      |
| <b>POR</b>    | power-on reset                             |
| <b>PPP</b>    | Point-to-Point Protocol                    |
| <b>PPS</b>    | picture parameter set                      |
| <b>PRBS</b>   | pseudo random binary sequence              |
| <b>PRDT</b>   | physical region descriptor table           |
| <b>PSI</b>    | program specific information               |
| <b>PSK</b>    | phase shift keying                         |
| <b>PSRAM</b>  | pseudo static random access memory         |
| <b>RTCP</b>   | Real-time Transport Control Protocol       |
| <b>RTP</b>    | Real-time Transport Protocol               |
| <b>PT</b>     | packet type                                |
| <b>PTS</b>    | presentation time stamp                    |
| <b>PUB</b>    | PHY utility block                          |
| <b>PUSI</b>   | payload unit start indicator               |
| <b>PWM</b>    | pulse width modulation                     |

**Q**

|             |                                 |
|-------------|---------------------------------|
| <b>Q</b>    | quadrant                        |
| <b>QAM</b>  | quadrature amplitude modulation |
| <b>QDR</b>  | quad data rate                  |
| <b>QoS</b>  | quality of service              |
| <b>QP</b>   | quantizer parameter             |
| <b>QPSK</b> | quaternary phase shift keying   |

**R**



|               |                                                        |
|---------------|--------------------------------------------------------|
| <b>RAM</b>    | random access memory                                   |
| <b>RAS</b>    | row address signal                                     |
| <b>RC</b>     | resistor-capacitor                                     |
| <b>RCA</b>    | Radio Corporation of America                           |
| <b>RCRC</b>   | response CRC error                                     |
| <b>RE</b>     | response error                                         |
| <b>RF</b>     | radio frequency                                        |
| <b>RGB</b>    | red-green-blue                                         |
| <b>RGMII</b>  | reduced gigabit media independent interface            |
| <b>RH</b>     | relative humidity                                      |
| <b>RoHS</b>   | restriction of the use of certain hazardous substances |
| <b>ROI</b>    | region of interest                                     |
| <b>ROM</b>    | read-only memory                                       |
| <b>ROP</b>    | raster operation                                       |
| <b>RPR</b>    | resilient packet ring                                  |
| <b>RLDRAM</b> | reduced latency dynamic random access memory           |
| <b>RMII</b>   | reduced media-independent interface                    |
| <b>RS</b>     | Reed-Solomon                                           |
| <b>RTC</b>    | real-time clock                                        |
| <b>RTO</b>    | response timeout                                       |
| <b>RTS</b>    | request to send                                        |
| <b>RVDS</b>   | RealView development suite                             |
| <b>RX</b>     | receive                                                |
| <b>RXDR</b>   | receive FIFO data request                              |

**S**

|             |                                       |
|-------------|---------------------------------------|
| <b>SAP</b>  | service access point                  |
| <b>SAD</b>  | sum of absolute difference            |
| <b>SAR</b>  | successive approximation              |
| <b>SATA</b> | serial advanced technology attachment |
| <b>SAV</b>  | start of active video                 |
| <b>SBE</b>  | start-bit error                       |
| <b>SBP</b>  | secure boot procedure                 |



|              |                                          |
|--------------|------------------------------------------|
| <b>SCD</b>   | start code detect                        |
| <b>SCI</b>   | smart card interface                     |
| <b>SCL</b>   | serial clock                             |
| <b>SCR</b>   | system clock reference                   |
| <b>SCS</b>   | secure chipset start-up                  |
| <b>SCU</b>   | snoop control unit                       |
| <b>SD</b>    | secure digital                           |
| <b>SDA</b>   | serial data                              |
| <b>SDB</b>   | set device bits                          |
| <b>SDH</b>   | synchronous digital hierarchy            |
| <b>SDHC</b>  | secure digital high capacity             |
| <b>SDI</b>   | serial digital interface                 |
| <b>SDIO</b>  | secure digital input/output              |
| <b>SDK</b>   | software development kit                 |
| <b>SDRAM</b> | synchronous dynamic random access memory |
| <b>SDV</b>   | system design verification               |
| <b>SI</b>    | specific information                     |
| <b>SIO</b>   | sonic input/output                       |
| <b>SLC</b>   | single-level cell                        |
| <b>SMI</b>   | static memory interface                  |
| <b>SNAP</b>  | subnetwork access point                  |
| <b>SNR</b>   | signal-to-noise ratio                    |
| <b>SNTF</b>  | serial ATA notification                  |
| <b>SOA</b>   | semiconductor optical amplifier          |
| <b>SoC</b>   | system-on-chip                           |
| <b>SONET</b> | synchronous optical network              |
| <b>SOP</b>   | start of PES                             |
| <b>SP</b>    | simple profile                           |
| <b>SPDIF</b> | Sony/Philips digital interface           |
| <b>SPI</b>   | serial peripheral interface              |
| <b>SPS</b>   | sequence parameter set                   |
| <b>SRAM</b>  | static random access memory              |
| <b>SRP</b>   | Session Request Protocol                 |



|                |                                         |
|----------------|-----------------------------------------|
| <b>SSA</b>     | secure software authentication          |
| <b>SSD</b>     | secure software download                |
| <b>SSMC</b>    | synchronous static memory controller    |
| <b>SSP</b>     | synchronous serial port                 |
| <b>SSRAM</b>   | synchronous static random access memory |
| <b>SSTL-18</b> | stub series terminated logic for 1.8 V  |
| <b>STA</b>     | station                                 |
| <b>STB</b>     | set-top box                             |
| <b>STM-1</b>   | synchronous transport module level 1    |
| <b>SVB</b>     | selective voltage bing                  |
| <b>SYNC</b>    | synchronization                         |
| <b>SYS</b>     | system                                  |

## T

|               |                                 |
|---------------|---------------------------------|
| <b>TBD</b>    | to be determined                |
| <b>TBGA</b>   | tape ball grid array            |
| <b>TC</b>     | traffic class                   |
| <b>TCP</b>    | Transmission Control Protocol   |
| <b>TD</b>     | TLP digest                      |
| <b>TDES</b>   | triple data encryption standard |
| <b>TDE</b>    | two-dimensional engine          |
| <b>TE</b>     | tearing effect                  |
| <b>TEI</b>    | transport error indicator       |
| <b>TFD</b>    | task file data                  |
| <b>TFPBGA</b> | tape fine-pitch ball grid array |
| <b>TFT</b>    | thin-film technology            |
| <b>TI</b>     | Texas Instruments               |
| <b>TLV</b>    | type-length-value               |
| <b>TOE</b>    | TCP/IP offload engine           |
| <b>TP</b>     | transponder                     |
| <b>TPIT</b>   | TS packet index table           |
| <b>TR</b>     | timing recovery                 |
| <b>TS</b>     | transport stream                |



|              |                              |
|--------------|------------------------------|
| <b>TSI</b>   | transport stream interface   |
| <b>TT</b>    | teletext                     |
| <b>TV</b>    | television                   |
| <b>TVACT</b> | top vertical active area     |
| <b>TVBB</b>  | top vertical back blank      |
| <b>TVFB</b>  | top vertical front blank     |
| <b>TVS</b>   | transient voltage suppressor |
| <b>TX</b>    | transmit                     |
| <b>TXDR</b>  | transmit FIFO data request   |

**U**

|               |                                             |
|---------------|---------------------------------------------|
| <b>UART</b>   | universal asynchronous receiver transmitter |
| <b>U-boot</b> | universal boot loader                       |
| <b>UC</b>     | unexpected completion                       |
| <b>UDP</b>    | User Datagram Protocol                      |
| <b>ULPI</b>   | UTMI low pin interface                      |
| <b>UPnP</b>   | universal plug and play                     |
| <b>UR</b>     | unsupported request                         |
| <b>USB</b>    | universal serial bus                        |
| <b>USIM</b>   | universal subscriber identity module        |
| <b>UTMI</b>   | USB 2.0 transceiver macrocell interface     |

**V**

|             |                                |
|-------------|--------------------------------|
| <b>VACT</b> | vertical active area           |
| <b>VAD</b>  | voice activity detector        |
| <b>VAPU</b> | video analysis&process unit    |
| <b>VBB</b>  | vertical back blank            |
| <b>VBI</b>  | vertical blanking interval     |
| <b>VBR</b>  | variable bit rate              |
| <b>VCC</b>  | common connector voltage       |
| <b>VCO</b>  | voltage controller oscillator  |
| <b>VCM</b>  | variable coding and modulation |
| <b>VCMP</b> | video compress                 |



|              |                                    |
|--------------|------------------------------------|
| <b>VCXO</b>  | voltage control crystal oscillator |
| <b>VDA</b>   | video detection analysis           |
| <b>VDH</b>   | video decoder for high-definition  |
| <b>VDM</b>   | video decoding module              |
| <b>VDEC</b>  | video decoding                     |
| <b>VDP</b>   | video display                      |
| <b>VEDU</b>  | video encoding/decoding unit       |
| <b>VENC</b>  | video encoding                     |
| <b>VFB</b>   | vertical front blank               |
| <b>VFMW</b>  | video firmware                     |
| <b>VFP</b>   | vertical front porch               |
| <b>VGA</b>   | video graphics array               |
| <b>VI</b>    | video input                        |
| <b>VIC</b>   | vector interrupt controller        |
| <b>VICAP</b> | video capture                      |
| <b>VIU</b>   | video input unit                   |
| <b>VLD</b>   | valid                              |
| <b>VLL</b>   | virtual leased line                |
| <b>VO</b>    | video output                       |
| <b>VOIE</b>  | voice encoder                      |
| <b>VOU</b>   | video output unit                  |
| <b>VPP</b>   | video pre-processing               |
| <b>VPS</b>   | video programming system           |
| <b>VPSS</b>  | video process subsystem            |
| <b>VPW</b>   | vertical pulse width               |
| <b>VSA</b>   | vertical sync start                |
| <b>VQE</b>   | voice quality enhancement          |
| <b>VQM</b>   | voice quality monitor              |

## W

|            |                |
|------------|----------------|
| <b>WDG</b> | watchdog       |
| <b>WE</b>  | write enable   |
| <b>WFE</b> | wait for event |



|             |                               |
|-------------|-------------------------------|
| <b>WFI</b>  | wait for interrupt            |
| <b>WRED</b> | weighted random early discard |
| <b>WSS</b>  | wide screen signaling         |

**X**

|             |                                      |
|-------------|--------------------------------------|
| <b>XAUI</b> | 10 gigabit attachment unit interface |
|-------------|--------------------------------------|

**Y**

|              |                                 |
|--------------|---------------------------------|
| <b>YAFFS</b> | yet another flash file system   |
| <b>YUV</b>   | luminance-bandwidth-chrominance |

**Z**

|            |             |
|------------|-------------|
| <b>ZME</b> | zoom engine |
|------------|-------------|



## **Contents**

---

|                                    |            |
|------------------------------------|------------|
| <b>B Ordering Information.....</b> | <b>B-1</b> |
|------------------------------------|------------|



# B Ordering Information

Figure B-1 illustrates the mark naming convention of Hi3796M V100.

Figure B-1 Mark naming convention



HiXXXX indicates the 6-digit product model before the part number.

The letter X in the part number indicates variable digits and is only for internal use.



**Table B-1** Packages

| Part Number          | Package  | Body Size                           | Pitch              |
|----------------------|----------|-------------------------------------|--------------------|
| Hi3796M RBC V10X XXX | PBGA 573 | 23 mm x 23 mm (0.91 in. x 0.91 in.) | 0.8 mm (0.031 in.) |

For example, if the part number is Hi3796M RBCV1010D0, it indicates that Hi3796M V100 with the BGA package supports Dolby but not Macrovision (Rovi) and DTS.



## **CAUTION**

According to the technical agreement between HiSilicon and providers of third-party software, HiSilicon has no rights to provide technical samples of the third-party software for other parties. Therefore, if the third-party software or chips that are provided for only authenticated users are involved (including but not limited to DD+ and DTS), ensure that you have obtained authentication from the third party when you place an order for the HiSilicon chip.